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1 General 


1.1 Introduction 


This document describes the specifications of the Ultrastar 7K3000, Deskstar 7K3000, an Hitachi Global Storage 
Technologies 3.5-inch 7200-rpm serial ATA interface hard disk drive with the following model numbers: 


Capacity Type Model 
Deskstar Ultrastar 
3TB DK7SAD300 HDS723030ALA640 HUA723030ALA640/1 
2TB DK7SAD200 Not Appliciable HUA723020ALA640/1 
Table 1 Type and Model# 
1.2 Glossary 
ESD Electrostatic Discharge 
Kbpi 1,000 bits per inch 
Ktpi 1,000 tracks per inch 
Gbps 1,000,000,000 bits per second 
Mbps 1,000,000 bits per second 
MB/s 1,000,000 bytes per second 
TB 1,000,000,000,000 bytes (for Drive Capacity) 
GB 1,000,000,000 bytes(for Drive Capacity) 
MB 1,048,576 bytes (for Memory Size) 
KB 1,024 bytes (for Memory Size) 
S.M.A.R.T. Self-Monitoring Analysis and Reporting Technology 
DFT Drive Fitness Test 
ADM Automatic Drive Maintenance 


1.3 General caution 

The drive can be damaged by shock or ESD (Electrostatic Discharge). Any damage sustained by the drive after 
removal from the shipping package and opening the ESD protective bag are the responsibility of the user. 

1.4 References 


Serial ATA II: Extensions to Serial ATA 1.0a revision 1.2 
Serial ATA International Organization: Serial ATA Revision 2.60 
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2 General features 


* Data capacities of 2TB/3TB 
e Spindle speeds of 7200 RPM 
e Fluid Dynamic Bearing motor 
e Dual Stage Actuator 
e Serial ATA interface 
e Sector format of 512 bytes/sector 
e Closed-loop actuator servo 
e Load/Unload mechanism, non head disk contact start/stop 
e Automatic Actuator lock 
e Ultrastar Seek time of 8.2 ms typical (without Command Overhead) 
e Sector Buffer size of 64MB 
(Upper 7632.5KB is used for firmware, this is typical value, it depends on firmware revision) 
e Ring buffer implementation 
e Write Cache 
* Native command queuing support 
e Automatic Error Recovery procedures for read and write commands 
e Self Diagnostics on Power on and resident diagnostics 
e Serial ATA Data Transfer 6/3/1.5Gbps 
e CHS and LBA mode 
e Power saving modes/Low RPM idle mode (APM) 
e S.M.A.R.T. (Self Monitoring and Analysis Reporting Technology) 
e Support security feature 
e 48 bit addressing feature 
e Adaptive zone formatting 
e RVS(Rotational Vibration Safeguard) 
e SATA-2.6 compliant 
e Support Full Disk Encryption (specific model only) 
e Support TCG Opal SSC (specific model only) 
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Part 1. Functional specification 
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3 Fixed disk subsystem description 


3.1 Control Electronics 


The drive is electronically controlled by a microprocessor, several logic modules, digital/analog modules, and 
various drivers and receivers. The control electronics performs the following major functions: 


e Controls and interprets all interface signals between the host controller and the drive. 

e Controls read write accessing of the disk media, including defect management and error recovery. 
e Controls starting, stopping, and monitoring of the spindle. 

e Conducts a power-up sequence and calibrates the servo. 


e Analyzes servo signals to provide closed loop control. These include position error signal and estimated 
velocity. 


e Monitors the actuator position and determines the target track for a seek operation. 

e Controls the voice coil motor driver to align the actuator in a desired position. 

e Constantly monitors error conditions of the servo and takes corresponding action if an error occurs. 
e Monitors various timers such as head settle and servo failure. 


e Performs self-checkout (diagnostics). 


3.2 Head disk assembly 


The head disk assembly (HDA) is assembled in a clean room environment and contains the disks and actuator 
assembly. Air is constantly circulated and filtered when the drive is operational. Venting of the HDA is accomplished 
via a breather filter. 


The spindle is driven directly by an in-hub, brushless, sensorless DC drive motor. Dynamic braking is used to quickly 
stop the spindle. 


3.3 Actuator 


The read/write heads are mounted in the actuator. The actuator is a swing-arm assembly driven by a voice coil 
motor. A closed-loop positioning servo controls the movement of the actuator. An embedded servo pattern supplies 
feedback to the positioning servo to keep the read/write heads centered over the desired track. 


The actuator assembly is balanced to allow vertical or horizontal mounting without adjustment. 


When the drive is powered off, the actuator automatically moves the head to the actuator ramp outside of the disk 
where it parks. 
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4 Drive characteristics 


This section describes the characteristics of the drive. 


4.1 Default logical drive parameters 


The default of the logical drive parameters in Identify Device data is as shown below. 


2TB model 3TB model 
Physical Layout 


512 
[Logical Layout — — 

16 

63 

16,383 

5 860,533,168 
3,000,592, 982,016 


Table 2 Formatted capacity 


Notes: ' Number of cylinders: For drives with capacities greater an 8.45 GB the IDENTIFY DEVICE information word 01 
limits the number of cylinders to 16,383 per the ATA specification. 


Å Logical layout: Logical layout is an imaginary drive parameter (that is, the number of heads) which is used to 
access the drive from the system interface. The Logical layout to Physical layout (that is, the actual Head and 
Sectors) translation is done automatically in the drive. The default setting can be obtained by issuing an IDENTIFY 
DEVICE command 


4.2 Data sheet 


MØRE 2TB 3TB 
‘interface transfer rate (MB/s) si 


Number of buffer segments (write) 


1Upper 7632.5 KB are used for firmware, this is typical value, it depends on firmware revision 


Table 3 Mechanical positioning performance 
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4.3 World Wide Name Assignment 


Hitachi GST 
Manufacturing Site Prachinburi, Thailand 


Ultrastar 7K3000 / Deskstar 7K3000 


000CCAh 


SHBU Block Assignment 223h/224h 225h 
Port/Node ID 11b 


Table 4 World Wide Name Assignment 


4.4 Drive organization 
4.4.1 Drive Format 


Upon shipment from Hitachi Global Storage Technologies manufacturing the drive satisfies the sector continuity in 
the physical format by means of the defect flagging strategy described in Section 5 on page 22 in order to provide 
the maximum performance to users. 


4.4.2 Cylinder allocation 


Physical cylinder is calculated from the starting data track of 0. It is not relevant to logical CHS. Depending on the 
capacity some of the inner zone cylinders are not allocated. 


Data cylinder 
This cylinder contains the user data which can be sent and retrieved via read/write commands and a spare area for 
reassigned data. 


Spare cylinder 
The spare cylinder is used by Hitachi Global Storage Technologies manufacturing and includes data sent from a 
defect location. 
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4.5 Performance characteristics 


Drive performance is characterized by the following parameters: 
e Command overhead 
e Mechanical positioning 
- Seek time 
- Latency 
e Data transfer speed 
e Buffering operation (Look ahead/Write cache) 


All the above parameters contribute to drive performance. There are other parameters that contribute to the 
performance of the actual system. This specification defines the characteristics of the drive, not the characteristics 
of the system throughput which depends on the system and the application. 


4.5.1 Command overhead 


Command overhead is defined as the time required 


e from the time H->D Reg FIS w/ command bit is sent by host 
e to the time 
e PIO Set Up FIS is sent by device(PIO Read/Write) 
e DATA FIS is sent by device(DMA Read) 
e DMA Activate FIS is sent by device(DMA Write) 
e DMA Set Up FIS is sent by device(NCQ Read/Write) 
e Seek Start (Read cache not hit or Seek) 
The table below gives average command overhead. 


Command type Typical time for NCQ command 
(Drive is in quiescent state) (ms) 


Read (Cache not hit) 


Typical time (ms) 


Read (Cache hit) 
0.015 
not applicable 


Table 5 Command overhead 


Hitachi hard disk drive specifications 
19 


4.5.2 Mechanical positioning 


4.5.2.1 Ultrastar Average seek time (without command overhead, including settling) 


Command Type Typical (ms) 


9.2 


Table 6 Average seek time 


The terms “Typical” and “Max” are used throughout this specification with the following meanings: 
Typical. The average of the drive population tested at nominal environmental and voltage conditions. 


Max. The maximum value measured on any one drive over the full range of the environmental and voltage 
conditions. (See Section 0, “Environment” and Section 6.3, “DC Power Requirements”) 


This spec. is applied for Ultrastar only. 


4.5.2.2 Single track seek time (without command overhead, including settling) 
Common to all models and all seek modes 
Function Typical (ms) Max (ms) 
Read 0.5 0.7 
Write 0.6 0.8 


Table 7 Single Track Seek Time 


Average latency 


Rotational speed Time for a revolution Average latency 
(ms) (ms) 


Table 8 Latency Time 


4.5.3 Drive ready time 


Typical (sec) 
5 Disk model 


Table 9 Drive ready time 


Ready The condition in which the drive is able to perform a media access command (such as 
read, write) immediately. 


Power on This includes the time required for the internal self diagnostics. 
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4.5.4 Operating modes 
4.5.4.1 Operating mode descriptions 


Operating mode Description 

Spin-up Start up time period from spindle stop or power down 

Seek Seek operation mode 

Write Write operation mode 

Read Read operation mode 

Unload Idle Spindle rotation at 7200 RPM with heads unloaded 

Idle Spindle motor is working normally. Servo system is sleeping and wake up for 100us 
every 10 revolutions. Commands can be received and processed immediately 

Standby Actuator is unloaded and spindle motor is stopped. Commands can be received 
immediately 

Sleep Actuator is unloaded and spindle motor is stopped. Only soft reset or hard reset can 


change the mode to standby 


Note: Upon power down or spindle stop a head locking mechanism will secure the heads in the OD parking position. 


4.5.4.2 Mode transition times 


Mode transition times are shown below. 


Max Transition 
time(sec) 


Typical Transition 


10 REM time(sec) 


From 


Idle 0 -> 7200 15 30 


Standby 7200 -> 0 Immediately 
Standby Immediately 
de 


Unload Idle Immediately Immediately 


Low RPM Idle Idle 6300 -> 7200 30 


Note: The command is processed immediately but there will be an actual Spin down time reflecting the seconds 
passed until the spindle motor stops. 


Standby 


Immediately 


Immediately 


Standby 


Immediately 


Unload idle 


Table 10 Mode transition times 
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5 Defect flagging strategy 


Media defects are remapped to the next available sector during the Format Process in manufacturing. The 
mapping from LBA to the physical locations is calculated by an internally maintained table. 
Shipped format 

e Data areas are optimally used. 

e No extra sector is wasted as a spare throughout user data areas. 

e All pushes generated by defects are absorbed by the spare tracks of the inner zone. 


skip skip 


Figure 1 PList physical format 


Defects are skipped without any constraint, such as track or cylinder boundary. The calculation 
from LBA to physical is done automatically by internal table. 
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6 Specification 


6.1 Electrical interface 


6.1.1 Connector location 


Refer to the following illustration to see the location of the connectors. 


SATA 


Figure 2 Connector location 


6.1.1.1 Signal connector 


The SATA signal connector is an 8-pin connector. Power connector is a 15-pin connector. 
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6.1.2 Signal definition(SATA) 


SATA has receivers and drivers to be connected to Tx+/- and Rx +/- Serial data signal. 
Defines the signal names of I/O connector pin and signal name. 


[Plug Connector pin definition | Signal | WO | 
s1 [GND | ——— dm o o — 


Differential signal A from Phy 


mime Jf Gn — 


Differential signal B from Phy 
Meme foer 
[s7 Joni |  — mme fom] — 
Key and spacing separate signal and power segments 
Pi Jva | ssvpmer [as] — 
Pa [ves | -—-— ssvpomer [sa] — 
På [vas | -—=savpowerprecharge2ndmae [sv | | 
Pa fond | stme fom] — 
ps [ea | —2ndmæe [cm] — 
Pe [eoa | —2ndmæe [coa — 
Pz [vs | 5V powerpre-charge,2nd Maie | s | | 
pa [s | ove [sv] — 
Power [Po [s | ~~ power fv | 
Gnd 


Table 11 Interface connector pins and I/O signals 


6.1.2.1 TX+ / TX- 


These signals are the outbound high-speed differential signals that are connected to the serial ATA cable 
6.1.2.2 RX+ / RX- 
These signals are the inbound high-speed differential signals that are connected to the serial ATA cable. 


The following standard shall be referenced about signal specifications. 
Serial ATA: High Speed Serialized AT Attachment Revision 1.0a 7-January -2003 


6.1.2.3 5V PRECHARGE 


+5 Vdc power that is available on the extended pins. This is used for pre-charging the I/O module. 
The enclosure shall provide for a current limit of 4.5 A peak on each 5V pre-charge pin (R=1.1 Ohms).These 
signals are the inbound high-speed differential signals that are connected to the serial ATA cable. 
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6.1.2.4 12V PRECHARGE 


+12 Vdc power that is available on the extended pins. This is used for pre-charging the 12V circuitry in the I/O 
Option slot module. 

The enclosure shall be capable of supplying 2.4 A peak on each 12 V pre-charge pin (R=5 Ohms). These 
signals are the inbound high-speed differential signals that are connected to the serial ATA cable. 


6.1.3 Out of band signaling(SATA) 


COMRESET/COM NT ==] H R] t2 RES 


COMWAKE = | t4 


HHHHHHHHHHHHEHH 


Figure 3 the timing of COMRESET, COMINIT and COMWAKE 


| PARAMETER DESCRIPTION Nominal (ns) 
ALIGN primitives 106.7 


| | Spacing pf 30 ”fEf 
| o B | ALIGN primitives 106.7 
[wf  spacng CS 106.7 


Table 12 Parameter descriptions 
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6.2 Environment 


6.2.1 Temperature and humidity 


Operating conditions 

Temperature 5 to 60°C 

Relative humidity 8 to 90% non-condensing 
Maximum wet bulb temperature 29.4°C non-condensing 
Maximum temperature gradient 20°C/Hour 

Altitude —300 to 3,048 m 


Temperature -40 to 70°C 

Relative humidity 5 to 95% non-condensing 
Maximum wet bulb temperature 35°C non-condensing 
Maximum temperature gradient 30°C/Hour 

Altitude —300 to 12,000 m 


Table 13 Temperature and humidity 


1. The system is responsible for providing sufficient ventilation to maintain a surface temperature below 
65°C at the center of the top cover of the drive. 


2. Noncondensing conditions should be maintained at any time. 
3. Maximum storage period within shipping package is one year 
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Figure 4 Limits of temperature and humidity 


Note: Storage temperature range is 0 to 70*C 


6.2.2 Corrosion test 


The drive Shows no sign of corrosion inside and outside of the hard disk assembly and is functional after being 
subjected to seven days at 50*C with 90% relative humidity. 


6.2.3 Atmospheric condition 


Environments that contain elevated levels of corrosives (e.g. hydrogen sulfide, sulfur oxides, or hydrochloric 
acid) should be avoided. Care must be taken to avoid using any compound/material in a way that creates an 
elevated level of corrosive materials in the atmosphere surrounding the disk drive. Care must also be taken to 
avoid use of any organometallic (e.g. organosilicon or organotin) compound/material in a way that creates 
elevated vapor levels of these compounds/materials in the atmosphere surrounding the disk drive. 
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6.3 DC power requirements 


If SATA power supply cable is connected or disconnected to the SATA power connector, hot plug/unplug is 
allowed. 


6.3.1 Input voltage 


Input voltage During run and spin up atra Supply rise time 


+5 Volts Supply 5V + 5% —0.3 to 5.5V 0 to 5sec 
+12 Volts Supply 12V +10% -8% —0.3 to 15.0V 


Table 14 Input voltage 


Caution : To avoid damage to the drive electronics, power supply voltage spikes must not exceed 
specifications. 


6.3.2 Power supply current (typical) 


Power supply current +5 Volts [mA] +12 Volts [mA] ee 
(values in milliamps. RMS) 


Idle ripple (peak-to-peak) 

Low RPM idle 

Low RPM idle ripple 

Unload mls Average 

EE ER 


Random pw peapea | mm 8 
Random R/W peak(Deskstar) 700 1700 : 
| 
Startuptma) == 1200 | 200 | | 
Sandoyar | mo | 7 09 
[Sleep average == I 470 | 7 [os] 


Table 15 Power supply current 


Except for a peak of less than 100 us duration 
1 Random R/W : 40 IOPS / 16 Blocks Random Write and Random Read 
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6.3.3 Power supply generated ripple at drive power connector 


Mim Vp) 


+5V DC 
+12V DC 250 


Table 16 Power supply generated ripple at drive power connector 


During drive start up and seeking 12-volt ripple is generated by the drive (referred to as dynamic loading). If the 
power of several drives is daisy chained together, the power supply ripple plus the dynamic loading of the other 
drives must remain within the above regulation tolerance. A common supply with separate power leads to each 
drive is a more desirable method of power distribution. 


To prevent external electrical noise from interfering with the performance of the drive, the drive must be held by 
four screws in a user system frame which has no electrical level difference at the four screws position and has 
less than +300 millivolts peak to peak level difference to the ground of the drive power connector. 
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6.4 Reliability 
6.4.1 Data integrity 


No more than one sector is lost at Power loss condition during the write operation when the write cache option is 
disabled. If the write cache option is active, the data in write cache will be lost. To prevent the loss of customer 
data, it is recommended that the last write access before power off be issued after setting the write cache off. 


6.4.2 Cable noise interference 


To avoid any degradation of performance throughput or error rate when the interface cable is routed on top or 
comes in contact with the HDA assembly, the drive must be grounded electrically to the system frame by four 
screws. The common mode noise or voltage level difference between the system frame and power cable ground 
or AT interface cable ground should be in the allowable level specified in the power requirement section. 


6.4.3 Load/Unload 


The product supports a minimum of 600,000 normal load/unloads in a 40° C environment. 
Load/unload is invoked by transition of the HDD's power mode. 

Idle <-> unload idle 

Idle <-> Low rpm idle 


6.4.4 Start/stop cycles 

The drive withstands a minimum of 50,000 start/stop cycles in a 40° C environment and a minimum of 10,000 
start/stop cycles in extreme temperature or humidity within the operating range. 

6.4.5 Preventive maintenance 


None 


6.4.6 Data reliability 


Probability of not recovering data is 1 in 10" bits read for Ultrastar, 1 in 10" bits read for Deskstar. 


LDPC on the fly/ offline data correction 
e 576 bit LDPC in 512 byte format 
e This implementation recovers maximum 300 bits single burst error by on the fly correction and 
maximum 425 bits single burst error by offline correction 
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6.5 Mechanical specifications 


6.5.1 Physical dimensions 


101.85 MAX 


BREATHER HOLE DIA(*2)02+0.4 25.55 +0.4 


*2 DO NOT COVER THE BREATHER HOLE 
*1 101.6+/-0.25 IS APPLIED FOR HATCHED AREA ONLY. 


Figure 5 Top and side views with breather hole location and mechanical dimensions 


All dimensions are in millimeters. 
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6X_6-32 UNC 


Max. penetration 6.1mm 


4X 6-32 UNC 
Max. penetration 4mm 


2X 28.5+0.5 
2X 6040.2 


w| ™ 
2X 95.25+0.2 = 2 
oj w 
aj * 
-| + 
+| + 
x| x 
wl N 


Figure 6 Bottom and side views with mounting hole locations 


All dimensions in the above figure are in millimeters. 


The breather hole must be kept uncovered in order to keep the air pressure inside of the disk enclosure equal to 
external air pressure. 


The following table shows the physical dimensions of the drive. 
Height (mm) Width (mm) Length (mm) Weight (grams) 
26.1 MAX 101.6 + 0.25 147 MAX 690 Typical 


Table 17 Physical Dimensions 
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6.5.2 Connector locations 


13.43 REF 33.39 


Figure 7 Connector locations 


6.5.3 Drive mounting 


The drive will operate in all axes (6 directions). Performance and error rate will stay within specification limits if 
the drive is operated in the other orientations from which it was formatted. 


For reliable operation, the drive must be mounted in the system securely enough to prevent excessive motion or 
vibration of the drive during seek operation or spindle rotation, using appropriate screws or equivalent mounting 
hardware. 


The recommended mounting screw torque is 0.6 - 1.0 Nm (6-10 Kgf.cm). 


The recommended mounting screw depth is 4mm maximum for bottom and 6.1 mm maximum for horizontal 
mounting. 


Drive level vibration test and shock test are to be conducted with the drive mounted to the table using the bottom 
four screws. 


6.5.4 Heads unload and actuator lock 


Heads are moved out from disks (unload) to protect the disk data during shipping, moving, or storage. Upon 
power down, the heads are automatically unloaded from disk area and the locking mechanism of the head 
actuator will secure the heads in unload position. 
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6.6 Vibration and shock 


All vibration and shock measurements recorded in this section are made with a drive that has no mounting 
attachments for the systems. The input power for the measurements is applied to the normal drive mounting 
points. 


6.6.1 Operating vibration 


6.6.1.1 Random vibration (Linear) 


The test is 30 minutes of random vibration using the power spectral density (PSD) levels shown below in each of 
three mutually perpendicular axes. The disk drive will operate without non-recoverable errors when subjected to 
the below random vibration levels. 


150 RMS 
ku JOE LETE 


2 1.9 x 1.1x 1.1x 7.7X 9.6 x 9.6 x 4.8 x 4.8 
[(m/sec')'/Hz] | 496-3 | 106-1 | 10E-1 | 106-1 10E-2 | 10E-2 | 10E-2 | x10E-2 


Table 18 Random vibration PSD profile break points (operating) 


The overall RMS (root mean square) level is 6.57 m/sec? (0.67 G). 


6.6.1.2 Swept sine vibration (Linear) 


The drive will meet the criteria shown below while operating in the specified conditions: 


* No errors occur with 4.9 m/sec” (0.5 G) 0 to peak, 5 to 300 to 5 Hz sine wave, 0.5 oct/min sweep rate 
with 3-minute dwells at two major resonances 


e No data loss occurs with 9.8 m/sec? (1 G) 0 to peak, 5 to 300 to 5 Hz sine wave, 0.5 oct/min sweep rate 
with 3-minute dwells at two major resonances 
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6.6.1.3 Random vibration (Rotational) 


The drive will meet the criteria shown below while operating in the specified conditions: 


* Less than 20% Performance degradation 


e The overall RMS ET Mean Square) level of vibration is 12.5Rad/sec*2. PSD oe is shown below. 


RMS 
| Frequency | 100 Hz | 10Hz | 200H2 | 800 Hz | 1000 Hz | Hz 1500 Hz (Radis 2) 


1.90E-02 1.90E-02 1.90E-01 1.90E-01 5.33E-02 7.77E-03 ps 


Table 19 Random vibration (Rotational) PSD profile break points (Deskstar) 


100 1000 1500 1700 RMS 
Er LALM LA (ads 


2) 2 1.90E- | 1.90E- | 1.87E- | 1.87E- | 5.33E- | 7.70E- | 4.00E- | 4.00E- 


Table 20 Random vibration (Rotational) PSD profile break points (Ultrastar) 


6.6.2 Non-operating vibration 

The drive does not sustain permanent damage or loss of previously recorded data after being subjected to the 
environment described below 

6.6.2.1 Random vibration 


The test consists of a random vibration applied for each of three mutually perpendicular axes with the time 
duration of 10 minutes per axis. The PSD levels for the test simulate the shipping and relocation environment 
shown below. The overall RMS are Mean ae | or level of vibration is 10.2 m/sec? (1.04 LE 


| Frequency | 2Hz | 


ae yl ML 096 EF 289 El 962 
Hz] 


Table 21 Random vibration PSD profile break points (nonoperating) 


6.6.2.2 Swept sine vibration 


e 19.6 m/sec? (2 G) (Zero to peak), 5 to 500 to 5 Hz sine wave 
e 0.5 oct/min sweep rate 
e 3 minutes dwell at two major resonances 
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6.6.3 Operating shock 


The drive meets the following criteria while operating in the conditions described below. The shock test consists 
of 10 shock inputs in each axis and direction for total of 60. There must be a delay between shock pulses long 
enough to allow the drive to complete all necessary error recovery procedures. 


e No error occurs with a 98.1 m/sec? (10 G) half-sine shock pulse of 11 ms duration 
* No data loss occurs with a 294 m/sec? (30 G) half-sine shock pulse of 4 ms duration. 


* No data loss occurs with a 686 m/sec? (70 G) half-sine shock pulse of 2 ms duration. 


6.6.4 Non-operating shock 
The drive will operate without non-recoverable errors after being subjected to shock pulses with the following 
characteristics. 
6.6.4.1 Trapezoidal shock wave 
* Approximate square (trapezoidal) pulse shape 
e Approximate rise and fall time of pulse ist ms 


* Average acceleration level is 490 m/sec? (50 G). (Average response curve value during the time following 
the 1 ms rise time and before the 1 ms fall with a time "duration of 11 ms") 


e Minimum velocity change is 4.23 m/sec 
6.6.4.2 Sinusoidal shock wave 


The shape is approximately half-sine pulse. The figure below shows the maximum acceleration level and 
duration. 


Acceleration level (misec*) Duration (ms) 
2940(300G) 


1470(150G) 


Table 22 Sinusoidal shock wave 


6.6.5 Non-operating Rotational shock 


All shock inputs shall be applied around the actuator pivot axis. 


| Duration |  Radlsed | 


30,000 
20,000 


Table 23 Rotational Shock 
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6.7 Acoustics 


The upper limit criteria of the octave sound power levels are given in Bels relative to one picowatt and are shown 
in the following table. The sound power emission levels are measured in accordance with ISO 7779. 


Mode 7200rpm Ultrastar (Typical / Max) 
Idle 2.9/3.4 
Operating 3.6/4.0 


Table 24 Sound power levels for Ultrastar 


Mode 7200rpm Deskstar (Typical / Max) 
Idle 2.9/3.4 
Operating 3.0/3.5 


Table 25 Sound power levels for Deskstar 


Mode definition: 


Idle mode. The drive is powered on, disks spinning, track following, unit ready to receive and respond to 
interface commands. 


Operating mode. Continuous random cylinder selection and seek operation of the actuator with a dwell 
time at each cylinder. The seek rate for the drive is to be calculated as shown below: 


e Dwell time = 0.5 x 60/RPM 


e Seek rate = 0.4 / (Average seek time + Dwell time) 


6.8 Identification labels 


The following labels are affixed to every drive shipped from the drive manufacturing location in accordance with 
the appropriate hard disk drive assembly drawing: 


O A label containing the Hitachi logo, the Hitachi Global Storage Technologies part number, and the statement 
“Made by Hitachi Global Storage Technologies Inc.” or Hitachi Global Storage Technologies approved 
equivalent 


O A label containing the drive model number, the manufacturing date code, the formatted capacity, the 
place of manufacture, UL/CSA/TUV/CE/C-Tick mark logos and WEEE/China RoHS logos 


O A bar code label containing the drive serial number 
O A label containing the jumper pin description 
O A user designed label per agreement 


The above labels may be integrated with other labels. 
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6.9 Safety 


6.9.1 UL and CSA standard conformity 


The product is qualified per UL60950-1 : Second Edition and CAN/CSA-C22.2 No.60950-1-07 Second Edition, 
for use in Information Technology Equipment including Electric Business Equipment. 


The UL recognition or the CSA certification is maintained for the product life. 
The UL and C-UL recognition mark or the CSA monogram for CSA certification appear on the drive. 


6.9.2 German Safety Mark 


The product is approved by TUV on Test requirement: EN60950-1 : 2006+A11 but the GS mark is not applicable 
to internal devices such as this product. 


6.9.3 Flammability 


The printed circuit boards used in this product are made of material with the UL recognized flammability rating of 
V-1 or better. The flammability rating is marked or etched on the board. All other parts not considered electrical 
components are made of material with the UL recognized flammability rating of V-2 minimum basically. 


6.9.4 Safe handling 


The product is conditioned for safe handling in regards to sharp edges and corners. 


6.9.5 Substance restriction requirements 


The product complies with the Directive 2002/95/EC of the European Parliament on the restrictions of the use of 
the certain hazardous substances in electrical and electronic equipment (ROHS) and with Halogen free 
requirements based on the electronics industry standard, IEC 61249-2-21 (http://www.iec.ch/). 


6.9.6 Secondary circuit protection 


Spindle/VCM driver module includes 12 V over current protection circuit. 
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6.10 Electromagnetic compatibility 


When installed in a suitable enclosure and exercised with a random accessing routine at maximum data rate, 
the drive meets the following worldwide EMC requirements: 


e United States Federal Communications Commission (FCC) Rules and Regulations (Class B), Part 15. (A 
6 dB buffer shall be maintained on the emission requirements). 


* European Economic Community (EEC) directive number 76/889 related to the control of radio frequency 
interference and the Verband Deutscher Elektrotechniker (VDE) requirements of Germany 
(GOP).Spectrum Management Agency (SMA) EMC requirements of Australia. The SMA has approved 
two forms of C-Tick Marking for Hitachi Global Storage Technologies. 


6.10.1 CE Mark 


The product is declared to be in conformity with requirements of the following EC directives under the sole 
responsibility of Hitachi Global Storage Technologies Japan Ltd: 


Council Directive 2004/108/EC on the approximation of laws of the Member States relating to electromagnetic 
compatibility. 


6.10.2 C-Tick Mark 


The product complies with the following Australian EMC standard: 


Limits and methods of measurement of radio disturbance characteristics of information technology, AS/NZS 
3548 : 1995 Class B. 


6.10.3 BSMI Mark 


The product complies with the Taiwan EMC standard “Limits and methods of measurement of radio disturbance 
characteristics of information technology equipment, CNS 13438 Class B.” 


6.10.4 KC Mark 


The product complies with the Korea EMC standard. The regulation for certification of information and 
communication equipment is based on “Telecommunications Basic Act” and “Radio Waves Act” Korea EMC 
requirement are based technically on CISPR22 measurement standards and limits. KC standards are likewise 
based on IEC standards. 
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Part 2. Interface Specification 
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7 General 


7.1 Introduction 


This specification describes the host interface of HDS723030ALA64n / HUA7230xxALA64n / 
HDS5C3030ALA63n / HUA5C30xxALA64n. 


The interface conforms to the following working documents of Information technology with certain limitations 
described in the chapter 7.3 “Deviations from Standard” on page 41 
— Serial ATA II: Extensions to Serial ATA Revision 2.6 


7.2 Terminology 


Device indicates HDS723030ALA64n / HUA7230xxALA64n / HDS5C3030ALA63n / 
HUA5C30xxALA64n. 


Host Host indicates the system that the device is attached to. 


Device 


7.3 Deviations From Standard 


The device conforms to the referenced specifications, with deviations described below. 


Check Power Mode Check Power Mode command returns FFh to Sector Count Register when the 
device is in Idle mode. This command does not support 80h as the return value. 
COMRESET COMRESET response is not the same as that of Power On Reset. Refer to 


section 5.1, "Reset Response” for detail. 
Download Download command is aborted when the device is in security locked mode. 


COMRESET response time During 500ms from Power On Reset, COMINIT is not returned within 10ms as a 
response to COMRESET. 


Streaming Commands When the device is in standby mode, Streaming Commands can't be completed 
while waiting for the spindle to reach operating speed even if execution time 
exceeds specified CCTL(Command Completion Time Limit). The minimum CCTL 
is 50ms.CCTL is set to 50ms when the specified value is shorter than 50ms. 


Error Recover Control When the device is in standby mode, any command where error recovery time 

(SCT Command set) limit is specified can't be completed while waiting for the spindle to reach operating 
speed even if execution time exceeds specified recovery time limit. The minimum 
time limit is 6.5 second. When the specified time limit is shorter than 6.5 second, 
the issued command is aborted. 
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8 Registers 


In Serial ATA, the host adapter contains a set of registers that shadow the contents of the traditional device 
registers, referred to as the Shadow Register Block. Shadow Register Block registers are interface registers 
used for delivering commands to the device or posting status from the device. About details, please refer to the 
Serial ATA Specification. 


In the following cases, the host adapter sets the BSY bit in its shadow Status Register and transmits a FIS to the 
device containing the new contents. 


= Command register is written in the Shadow Register Block 


= Device Control register is written in the Shadow Register Block with a change of state of the SRST bit 
= COMRESET is requested 


8.1 Alternate Status Register 


Alternate Status Register 


Table 26 Alternate Status Register 


This register contains the same information as the Status Register. The only difference is that reading this 
register does not imply interrupt acknowledge or clear a pending interrupt. See 8.13 "Status Register" on the 
page 46 for the definition of the bits in this register. 


8.2 Command register 
This register contains the command code being sent to the device. Command execution begins immediately 
after this register is written. The command set is shown in Table 68 Command Set on page 95. 


All other registers required for the command must be set up before writing the Command Register. 


8.3 Cylinder High Register 


This register contains the high order bits of the starting cylinder address for any disk access. At the end of the 
command, this register is updated to reflect the current cylinder number. 


In LBA Mode this register contains Bits 16-23. At the end of the command, this register is updated to reflect the 
current LBA Bits 16-23. 


The cylinder number may be from zero to the number of cylinders minus one. 


When 48-bit addressing commands are used, the "most recently written" content contains LBA Bits 16-23, and 
the "previous content" contains Bits 40-47. The 48-bit Address feature set is described in 9.12. 
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8.4 Cylinder Low Register 
This register contains the low order bits of the starting cylinder address for any disk access. At the end of the 
command, this register is updated to reflect the current cylinder number. 


In LBA Mode this register contains Bits 8-15. At the end of the command, this register is updated to reflect the 
current LBA Bits 8-15. 


The cylinder number may be from zero to the number of cylinders minus one. 


When 48-bit addressing commands are used, the "most recently written" content contains LBA Bits 8-15, and 
the "previous content" contains Bits 32-39. 


8.5 Data Register 


This register is used to transfer data blocks between the device data buffer and the host. It is also the register 
through which sector information is transferred on a Format Track command, and configuration information is 
transferred on an Identify Device command. 


All data transfers are 16 bits wide, except for ECC byte transfers, which are 8 bits wide. Data transfers are PIO 
only. 


The register contains valid data only when DRQ=1 in the Status Register. 


8.6 Device Control Register 


Device Control Register 


7 5 4 3 2 1 
HOB - - 1 SRST -IEN 


Table 27 Device Control Register 


Bit Definitions 


HOB HOB (high order byte) is defined by the 48-bit Address feature set. A write to 


any Command Register shall clear the HOB bit to zero. 


SRST (RST) Software Reset. The device is held reset when RST=1. Setting RST=0 
reenables the device. 


The host must set RST=1 and wait for at least 5 microseconds before setting 
RST=0, to ensure that the device recognizes the reset. 
JEN Interrupt Enable. When -IEN=0, and the device is selected, device interrupts to 
the host will be enabled. When -IEN=1, or the device is not selected, device 
interrupts to the host will be disabled. 
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8.7 Drive Address Register 


Drive Address Register 


7 6 5 4 3 2 1 0 
HIZ -WTG -H3 -H2 -H1 -HO -DS1 -DSO 


Table 28 Drive Address Register 


This register contains the inverted drive select and head select addresses of the currently selected drive. 


Bit Definitions 


piz High Impedance. This bit is not driven and will always be in a high impedance state. 
-WTG ; Pkt br . EE 
-Write Gate. This bit is 0 when writing to the disk device is in progress. 
-H3,-H2,-H1,-HO -Head Select. These four bits are the one's complement of the binary coded address 
of the currently selected head. -HO is the least significant. 
-DS1 -Drive Select 1. Drive select bit for device 1, active low. DS1=0 when device 1 (slave) 
is selected and active. 
-DSO -Drive Select 0. Drive Select bit for device 0, active low. DSO=0 when device 0 


(master) is selected and active. 


8.8  Device/Head Register 


Device/Head Register 


Table 29 Device/Head Register 


This register contains the device and head numbers. 


Bit Definitions 


L Binary encoded address mode select. When L=0, addressing is by CHS mode. When 
L=1, addressing is by LBA mode. 

DRV Device. This product ignores this bit. 

HS3,HS2,HS1,HSO Head Select. These four bits indicate binary encoded address of the head. HSO is the 


least significant bit. At command completion, these bits are updated to reflect the 
currently selected head. 

The head number may be from zero to the number of heads minus one. 

In LBA mode, HS3 through HSO contain bits 24-27 of the LBA. At command 
completion, these bits are updated to reflect the current LBA bits 24-27. 
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8.9 Error Register 


Error Register 


7 6 5 4 3 2 1 0 
ICRCE UNC 0 IDNF 0 ABRT TKONF AMNF 


Table 30 Error Register 


This register contains status from the last command executed by the device, or a diagnostic code. 


At the completion of any command except Execute Device Diagnostic, the contents of this register are valid 
always even if ERR=0 in the Status Register. 


Following a power on, a reset, or completion of an Execute Device Diagnostic command, this register contains a 
diagnostic code. See 0 on page 48 for the definition. 
Bit Definitions 


ICRCE (CRC) Interface CRC Error. ICRCE=1 indicates a CRC error occurred during FIS transmission or 
FIS reception. 


UNC Uncorrectable Data Error. UNC=1 indicates an uncorrectable data error has been 
encountered. 
IDNF (IDN) ID Not Found. IDN=1 indicates the requested sector's ID field could not be found. 


ABRT (ABT) Aborted Command. ABT=1 indicates the requested command has been aborted due to a 
device status error or an invalid parameter in an output register. 


TKONF (TON) Track 0 Not Found. TON=1 indicates track 0 was not found during a Recalibrate command. 


AMNF (AMN ; å ee 
( ) Address Mark Not Found. This product does not report this error. This bit is always zero. 


8.10 Features Register 


This register is command specific. This is used with the Set Features command, SMART Function Set command 
and Format Unit command. 


8.11 Sector Count Register 


This register contains the number of sectors of data requested to be transferred on a read or write operation 
between the host and the device. If the value in the register is set to 0, a count of 256 sectors (in 28-bit 
addressing) or 65,536 sectors (in 48-bit addressing) is specified. 


If the register is zero at command completion, the command was successful. If not successfully completed, the 
register contains the number of sectors which need to be transferred in order to complete the request. 


The contents of the register are defined otherwise on some commands. These definitions are given in the 
command descriptions. 
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8.12 Sector Number Register 


This register contains the starting sector number for any disk data access for the subsequent command. 
The sector number is from one to the maximum number of sectors per track. 


In LBA mode, this register contains Bits 0-7. At the end of the command, this register is updated to reflect the 
current LBA Bits 0-7. 


When 48-bit commands are used, the "most recently written" content contains LBA Bits 0-7, and the "previous 
content" contains Bits 24-31. 


8.13 Status Register 


Status Register 


7 6 5 4 3 2 1 0 
BSY DRDY DF Dee DRQ CORR IDX ERR 
ISERV 


Table 31 Status Register 


This register contains the device status. The contents of this register are updated whenever an error occurs and 
at the completion of each command. 


If the host reads this register when an interrupt is pending, it is considered to be the interrupt acknowledge. Any 
pending interrupt is cleared whenever this register is read. 


If BSY=1, no other bits in the register are valid. 


Bit Definitions 


BSY Busy. BSY=1 whenever the device is accessing the registers. The host should not read or write any 
registers when BSY=1. If the host reads any register when BSY=1, the contents of the Status Register 
will be returned. 


DRDY (RDY) Device Ready. RDY=1 indicates that the device is capable of responding to a command. RDY will be 
set to 0 during power on until the device is ready to accept a command. If the device detects an error 
while processing a command, RDY is set to 0 until the Status Register is read by the host, at which time 
RDY is set back to 1. 


DF Device Fault. This product does not support DF bit. DF bit is always zero. 


DSC Device Seek Complete. DSC=1 indicates that a seek has completed and the device head is settled over 
a track. DSC is set to 0 by the device just before a seek begins. When an error occurs, this bit is not 
changed until the Status Register is read by the host, at which time the bit again indicates the current 
seek complete status. 


When the device enters into or is in Standby mode or Sleep mode, this bit is set by device in spite of not 


spinning up. 
SERV (SRV) Service. This product does not support SERV bit. 
DRQ Data Request. DRQ=1 indicates that the device is ready to transfer a word or byte of data between the 


host and the device. The host should not write the Command register when DRQ=1. 


CORR (COR) Corrected Data. Always 0. 


IDX Index. IDX=1 once per revolution. Since IDX=1 only for a very short time during each revolution, the 
host may not see it set to 1 even if the host is reading the Status Register continuously. Therefore, the 
host should not attempt to use IDX for timing purposes. 


ERR Error. ERR=1 indicates that an error occurred during execution of the previous command. The Error 
Register should be read to determine the error type. The device sets ERR=0 when the next command 
is received from the host. 


Hitachi hard disk drive specifications 
46 


9 General Operation Descriptions 


9.1 Reset Response 


There are three types of reset in ATA as follows: 


Power On Reset (POR) The device executes a series of electrical circuitry diagnostics, spins 


up the HDA, tests speed and other mechanical parametric, and sets 
default values. 


COMRESET COMRESET is issued in Serial ATA bus. 
The device resets the interface circuitry as well as Soft Reset. 
Soft Reset (Software Reset) SRST bit in the Device Control Register is set, and then is reset. 


The device resets the interface circuitry according to the Set Features 
requirement. 


The actions of each reset are shown in Table 32. 


Aborting Host interface 
Aborting Device operation 
Initialization of hardware 


Internal diagnostic 
Spinning spindle 


Initialization of registers (*2) 
Reverting programmed parameters to default 
- Number of CHS 
(set by Initialize Device Parameter) 


- Multiple mode 
- Write cache 


- Read look-ahead 


- ECC bytes 


Disable Standby timer 


Power mode 


O ---- execute 
x --- not execute 


Table 32 Reset Response 


Table Notes 


(*1) 
(*2) 
(*3) 


(*4) 


(*5) 


Execute after the data in write cache has been written. 
Default value on POR is shown in 0 Default Register Values on page48. 


The Set Features command with Feature register = CCh enables the device to revert these 
parameters to the power on defaults. 


In the case of Sleep mode, the device goes to Standby mode. In other case, the device does 
not change current mode. 


Idle when Power-Up in Standby feature set is disabled. Standby when Power-Up in Standby 
feature set is enabled. 
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9.1.1 Register Initialization 


Error Diagnostic Code 


Sector Count olh 


Sector Number O1h 


Cylinder Low 
Cylinder High 
Device/Head 
Status 


Alternate Status 


Table 33 Default Register Values 


After power on, hard reset, or software reset, the register values are initialized as shown in Table 33. 


04h ECC circuitry error 


O5h Controller microprocessor error 


Table 34 Diagnostic Codes 


The meaning of the Error Register diagnostic codes resulting from power on, hard reset or the Execute Device 
Diagnostic command is shown in Table 34. 


9.2 Diagnostic and Reset considerations 


In each case of Power on Reset, COMRESET, Soft reset, and EXECUTE DEVICE DIAGNOSTIC command, the 
device is diagnosed. And Error register is set as shown in Table 34. 
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9.3 Sector Addressing Mode 


All addressing of data sectors recorded on the device's media is by a logical sector address. The logical CHS 
address for HDS723030ALA64n / HUA7230xxALA64n / HDS5C3030ALA63n / HUASC30xxALA64n is different 
from the actual physical CHS location of the data sector on the disk media. All addressing of data sectors 
recorded on the device's media. 


HDS723030ALA64n / HUA7230xxALA64n / HDS5C3030ALA63n / HUA5C30xxALA64n support both Logical 
CHS Addressing Mode and LBA Addressing Mode as the sector addressing mode. 


The host system may select either the currently selected CHS translation addressing or LBA addressing on a 
command-by-command basis by using the L bit in the DEVICE/HEAD register. So a host system must set the L 
bit to 1 if the host uses LBA Addressing mode. 


9.3.1 Logical CHS Addressing Mode 


The logical CHS addressing is made up of three fields: the cylinder number, the head number and the sector 
number. Sectors are numbered from 1 to the maximum value allowed by the current CHS translation mode but 
can not exceed 255(0FFh). Heads are numbered from 0 to the maximum value allowed by the current CHS 
translation mode but can not exceed 15(0Fh). Cylinders are numbered from 0 to the maximum value allowed by 
the current CHS translation mode but cannot exceed 65535(0FFFFh). 


When the host selects a CHS translation mode using the INITIALIZE DEVICE PARAMETERS command, the 
host requests the number of sectors per logical track and the number of heads per logical cylinder. The device 
then computes the number of logical cylinders available in requested mode. 


The default CHS translation mode is described in the Identify Device Information. The current CHS translation 
mode also is described in the Identify Device Information. 


9.3.2 LBA Addressing Mode 


Logical sectors on the device shall be linearly mapped with the first LBA addressed sector (Sector 0) being the 
same sector as the first logical CHS addressed sector (cylinder 0, head 0, sector 1). Irrespective of the logical 
CHS translation mode currently in effect, the LBA address of a given logical sector does not change. The 
following is always true: 


LBA = ( (cylinder * heads_per_cylinder + heads) 


* sectors_per_track ) + sector - 1 


where heads_per_cylinder and sectors_per_track are the current translation mode values. 


On LBA addressing mode, the LBA value is set to the following register. 


Device/Head <--- LBA 27-24 
bits 

Cylinder High <--- LBA 23-16 
bits 

Cylinder Low <--- LBA 15-8 
bits 

Sector Number <--- LBA 7-0 
bits 
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9.4 Power Management Feature 


The power management feature set permits a host to modify the behavior in a manner which reduces the power 
required to operate. The power management feature set provides a set of commands and a timer that enables a 
device to implement low power consumption modes. 


HDS723030ALA64n / HUA7230xxALA64n / HDS5C3030ALA63n / HUA5C30xxALA64n implement the following 
set of functions. 


1. A Standby timer 

2. Idle command 

3. Idle Immediate command 

4. Sleep command 

5. Standby command 

6. Standby Immediate command 


9.4.1 Power Mode 


The lowest power consumption when the device is powered on occurs in Sleep Mode. When in sleep mode, the 
device requires a reset to be activated. 


In Standby Mode the device interface is capable of accepting commands, but as the media may not immediately 
accessible, there is a delay while waiting for the spindle to reach operating speed. 


In Idle Mode the device is capable of responding immediately to media access requests. 


In Active Mode the device is under executing a command or accessing the disk media with read look-ahead 
function or writes cache function. 


9.4.2 Power Management Commands 


The Check Power Mode command allows a host to determine if a device is currently in, going to or leaving 
standby mode. 


The Idle and Idle Immediate commands move a device to idle mode immediately from the active or standby 
modes. The idle command also sets the standby timer count and starts the standby timer. 


The Standby and Standby Immediate commands move a device to standby mode immediately from the active or 
idle modes. The standby command also sets the standby timer count. 


The Sleep command moves a device to sleep mode. The device's interface becomes inactive at the completion 
of the sleep command. A reset is required to move a device out of sleep mode. When a device exits sleep mode 
it will enter Standby mode. 


9.4.3 Standby timer 


The standby timer provides a method for the device to automatically enter standby mode from either active or 
idle mode following a host programmed period of inactivity. If the device is in the active or idle mode, the device 
waits for the specified time period and if no command is received, the device automatically enters the standby 
mode. 


If the value of SECTOR COUNT register on Idle command or Standby command is set to 00h, the standby timer 
is disabled. 
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9.4.4 Interface Capability for Power Modes 


Each power mode affects the physical interface as defined in the following table: 


Active x x Active 
Idle 0 1 Active 
Standby 0 1 Inactive 
sleep x x Inactive 


Table 35 Power conditions 


Ready (RDY) is not a power condition. A device may post ready at the interface even though the media may not 
be accessible. 
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9.5 SMART Function 


The intent of Self-monitoring, analysis and reporting technology (SMART) is to protect user data and prevent 
unscheduled system downtime that may be caused by predictable degradation and/or fault of the device. By 
monitoring and storing critical performance and calibration parameters, SMART devices employ sophisticated 
data analysis algorithms to predict the likelihood of near-term degradation or fault condition. By alerting the host 
system of a negative reliability status condition, the host system can warn the user of the impending risk of a 
data loss and advise the user of appropriate action. 


9.5.1 Attributes 


Attributes are the specific performance or calibration parameters that are used in analyzing the status of the 
device. Attributes are selected by the device manufacturer based on that attribute's ability to contribute to the 
prediction of degrading or faulty conditions for that particular device. The specific set of attributes being used 
and the identity of these attributes is vendor specific and proprietary. 


9.5.2 Attribute values 


Attribute values are used to represent the relative reliability of individual performance or calibration attributes. 
The valid range of attribute values is from 1 to 253 decimal. Higher attribute values indicate that the analysis 
algorithms being used by the device are predicting a lower probability of a degrading or faulty condition existing. 
Accordingly, lower attribute values indicate that the analysis algorithms being used by the device are predicting 
a higher probability of a degrading or faulty condition existing. 


9.5.3 Attribute thresholds 


Each attribute value has a corresponding attribute threshold limit which is used for direct comparison to the 
attribute value to indicate the existence of a degrading or faulty condition. The numerical values of the attribute 
thresholds are determined by the device manufacturer through design and reliability testing and analysis. Each 
attribute threshold represents the lowest limit to which its corresponding attribute value can be equal while still 
retaining a positive reliability status. Attribute thresholds are set at the device manufacturer's factory and cannot 
be changed in the field. The valid range for attribute thresholds is from 1 through 253 decimal. 


9.5.4 Threshold exceeded condition 


If one or more attribute values, whose Pre-failure bit of their status flag is set, are less than or equal to their 
corresponding attribute thresholds, then the device reliability status is negative, indicating an impending 
degrading or faulty condition. 


9.5.5 SMART commands 


The SMART commands provide access to attribute values, attribute thresholds and other logging and reporting 
information. 


9.5.6 Off-line Read Scanning 


The device provides the off-line read scanning feature with reallocation. This is the extension of the off-line data 
collection capability. The device performs the entire read scan with reallocation for the marginal sectors to 
prevent the user data lost. 


If interrupted by the host during the read scanning, the device services the host command. 
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9.5.7 Error Log 


Logging of reported errors is supported. The device provides information on the last five errors that the device 
reported as described in SMART error log sector. The device may also provide additional vendor specific 
information on these reported errors. The error log is not disabled when SMART is disabled. Disabling SMART 
shall disable the delivering of error log information via the SMART READ LOG SECTOR command. 


If a device receives a firmware modification, all error log data is discarded and the device error count for the life 
of the device is reset to zero. 


9.5.8 Self-test 


The device provides the self-test features which are initiated by SMART Execute Off-line Immediate command. 
The self-test checks the fault of the device, reports the test status in Device Attributes Data and stores the test 
result in the SMART self-test log sector as described in SMART self-test log data structure. All SMART attributes 
are updated accordingly during the execution of self-test. 


If interrupted by the host during the self-tests, the device services the host command. 
If the device receives a firmware modification, all self-test log data is discarded. 
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9.6 Security Mode Feature Set 


Security Mode Feature Set is a powerful security feature. With a device lock password, a user can prevent 
unauthorized access to hard disk device even if the device is removed from the computer. 


The following commands are supported for this feature. 


Security Set Password 
Security Unlock 
Security Erase Prepare 
Security Erase Unit 
Security Freeze Lock 


Security Disable Password 


(‘F1'h) 
(F2'h) 
(‘F3'h) 
(‘F4'h) 
(‘F5'h) 
(‘F6'h) 


9.6.1 Security mode 


Following security modes are provided. 


Device Locked mode 


Device Unlocked mode 


Device Frozen mode 


The device disables media access commands after power on. Media access 
commands are enabled by either a security unlock command or a security erase 
unit command. 


The device enables all commands. If a password is not set this mode is entered 
after power on, otherwise it is entered by a security unlock or a security erase 
unit command. 


The device enables all commands except those which can update the device 
lock function, set/change password. The device enters this mode via a Security 
Freeze Lock command. It cannot quit this mode until power off. 


9.6.2 Security Level 


Following security levels are provided. 


High level security 


Maximum level security 


When the device lock function is enabled and the User Password is forgotten the 
device can be unlocked via a Master Password. 


When the device lock function is enabled and the User Password is forgotten 
then only the Master Password with a Security Erase Unit command can unlock 
the device. Then user data is erased. 
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9.6.3 Password 


This function can have 2 types of passwords as described below. 


Master Password When the Master Password is set, the device does NOT enable the Device Lock 
Function, and the device can NOT be locked with the Master Password, but the Master 
Password can be used for unlocking the device locked. 


Identify Device Information word 92 contains the value of the Master Password Revision 
Code set when the Master Password was last changed. Valid values are 0001h through 
FFFEh. 


User Password The User Password should be given or changed by a system user. When the User 
Password is set, the device enables the Device Lock Function, and then the device is 
locked on next power on reset or hard reset. 


The system manufacturer/dealer who intends to enable the device lock function for the end users, must set the 
master password even if only single level password protection is required. 


9.6.4 Operation example 


9.6.4.1 Master Password setting 


The system manufacturer/dealer can set a new Master Password from default Master Password using the 
Security Set Password command, without enabling the Device Lock Function. 


The Master Password Revision Code is set to FFFEh as shipping default by the HDD manufacturer 
9.6.4.2 User Password setting 


When a User Password is set, the device will automatically enter lock mode the next time the device is powered 
on. 


(Ref.) 
< Setting Password > < No Setting Password > 
POR POR 
V 
Set Password with User Password 
V V 
Normal operation Normal operation 
V V 
Power off Power off 
POR —> Device locked mode POR —> Device unlocked mode 


Figure 8 Initial Setting 
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9.6.4.3 Operation from POR after User Password is set 


When Device Lock Function is enabled, the device rejects media access command until a Security Unlock 
command is successfully completed. 


Unlock CMD 


Password 
Match ? 


Y 


Enter Device 
Unlock mode 


POR 


I 


Device Locked mode <——_—__ 


Erase Prepare Media access 


command (*1) 


Non-Media access 
command (*1) 


Erase Unit 
Password 
Match ? 


Reject Complete 
a ae, |r| 


Y 


Complete 
Erase Unit 


Lock function 
Disable 


Normal operation : All commands are available 


Freeze Lock command 


Enter Device Frozen mode 
Normal Operation except Set Password, 
Disable Password, Erase Unit, Unlock commands. 


Figure 9 Usual Operation 


(*1) Refer to 9.6.5 on the page .58 
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9.6.4.4 User Password Lost 


If the User Password is forgotten and High level security is set, the system user can't access any data. However, 
the device can be unlocked using the Master Password. 


If a system user forgets the User Password and Maximum security level is set, data access is impossible. 
However, the device can be unlocked using the Security Erase Unit command to unlock the device and erase all 
user data with the Master Password. 


User Password Lost 


V High 
LEVEL ? > Unlock CMD with Master Password 


Maximum 


Erase Prepare Command 
Erase Unit Command 
with Master Password 


V 
Normal operation but data lost Normal operation 


Figure 10 Password Lost 


9.6.4.5 Attempt limit for SECURITY UNLOCK command 


The SECURITY UNLOCK command has an attempt limit. The purpose of this attempt limit is to prevent that 
someone attempts to unlock the drive by using various passwords many times. 


The device counts the password mismatch. If the password does not match, the device counts it up without 
distinguishing the Master password and the User password. If the count reaches 5, EXPIRE bit (bit 4) of Word 
128 in Identify Device information is set, and then SECURITY ERASE UNIT command and SECURITY 
UNLOCK command are aborted until a hard reset or a power off. The count and EXPIRE bit are cleared after a 
power on reset or a hard reset. 
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9.6.5 Command Table 


This table shows the device's response to commands when the Security Mode Feature Set (Device lock 
function) is enabled. 


de  v setae | eoe | Executable | 


SCT Error Recovery Control Command aborted Executable Executable 


SCT Feature Control Command aborted Executable Executable 
SCT Data Table Command aborted Executable Executable 
SCT Read Status Executable Executable Executable 
Security Disable Password Command aborted Executable Command aborted 
Security Erase Prepare Executable Executable Command aborted 


Table 36 Command table for device lock operation -1 
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Command Locked Mode Unlocked Mode Frozen Mode 


Security Erase Unit Command aborted 
Security Freeze Lock Executable 
Security Set Password Command aborted 
Security Unlock Command aborted 
Set Features Executable 
Set Max Address Executable 
Set Max Address Ext Executable 
Set Multiple Mode Executable 
SMART Disable Operations Executable 
SMART Enable/Disable Attributes Autosave Executable 
SMART Enable Operations Executable 
SMART Execute Off-line Immediate Executable 
SMART Read Attribute Values Executable 
SMART Read Attribute Thresholds Executable 
SMART Return Status Executable 
SMART Save Attribute Values Executable 
SMART Read Log Sector Executable 
SMART Write Log Sector Executable 
SMART Enable/Disable Automatic Off-Line Executable 
Standby Executable 
Standby Immediate Executable 
Write Buffer Executable 
Write DMA Executable 
Write DMA Ext Executable 
Write DMA FUA Ext Executable 
Write FPDMA Queued Executable 
Write Log Ext Executable 
Write Multiple Executable 
Write Multiple Ext Executable 
Write Multiple FUA Ext Executable 
Write Sector(s) Executable 
Write Sector(s) Ext Executable 
Write Stream DMA Executable 
Write Stream PIO Executable 
Write Uncorrectable Ext Executable 


Table 37 Command table for device lock operation -2 
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9.7 Host Protected Area Feature 


Host Protected Area Feature is to provide the ‘protected area’ which can not be accessed via conventional 
method. This ‘protected area’ is used to contain critical system data such as BIOS or system management 
information. The contents of entire system main memory may also be dumped into ‘protected area’ to resume 
after system power off. 


The LBA/CYL changed by following command affects the Identify Device Information. 
The following set of commands is implemented for this function. 

Read Native Max ADDRESS (‘F8'h) 

Set Max ADDRESS (‘F9'h) 


9.7.1 Example for operation (In LBA mode) 


Assumptions: 


For better understanding, the following example uses actual values for LBA, size, etc. Since it is just an example, 
these values could be different. 


Device characteristics 


Capacity (native) : 6,498,680,832 byte (6.4GB) 

Max LBA (native) : 12,692,735 (OFFFFFh) 
Required size for protected area : 206,438,400 byte 
Required blocks for protected area : 403,200 (062700h) 
Customer usable device size : 6,292,242,432 byte (6.2GB) 
Customer usable sector count : 12,289,536 (BB8600h) 
LBA range for protected area : BB8600h to CLACFFh 


1. Shipping HDDs from HDD manufacturer 


When the HDDs are shipped from HDD manufacturer, the device has been tested to have usable capacity 
of 6.4GB besides flagged media defects not to be visible by system. 


2. Preparing HDDs at system manufacturer 


Special utility software is required to define the size of protected area and store the data into it. 
The sequence is: 


Issue Read Native Max Address command to get the real device maximum LBA. Returned value shows 
that native device Maximum LBA is 12,692,735 (CLACFFh) regardless of the current setting. 


Make entire device be accessible including the protected area by setting device Maximum LBA as 
12,692,735 (C1ACFFh) via Set Max Address command. The option could be either nonvolatile or 
volatile. 


Test the sectors for protected area (LBA >= 12,289,536 (BB8600h)) if required. 
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Write information data such as BIOS code within the protected area. 


Change maximum LBA using Set Max Address command to 12,289,535 (BB85FFh) with nonvolatile 
option. 
From this point, the protected area cannot be accessed till next Set Max Address command is issued. 


Any BlOSes, device drivers, or application software access the HDD as if that is the 6.2GB device 
because the device acts exactly the same as real 6.2GB device does. 


3. Conventional usage without system software support 

Since the HDD works as 6.2GB device, there is no special care to use this device for normal use. 
4. Advanced usage using protected area 

The data in the protected area is accessed by following. 


Issue Read Native Max Address command to get the real device maximum LBA. Returned value shows 
that native device Maximum LBA is 12,692,735 (CLACFFh) regardless of the current setting. 


Make entire device be accessible including the protected area by setting device Maximum LBA as 
12,692,735 (C1ACFFh) via Set Max Address command with volatile option. By using this option, 
unexpected power removal or reset will not make the protected area remained accessible. 


Read information data from protected area. 


Issue hard reset or POR to inhibit any access to the protected area. 


9.7.2 Security extensions 


1. Set Max Set Password 
2. Set Max Lock 

3. Set Max Freeze Lock 
4. Set Max Unlock. 


The Set Max Set Password command allows the host to define the password to be used during the current 
power on cycle. The password does not persist over a power cycle but does persist over a hardware or software 
reset. This password is not related to the password used for the Security Mode Feature set. When the password 
is set the device is in the Set Max Unlocked mode. The Set Max Lock command allows the host to disable the 
Set Max commands (except set Max Unlock) until the next power cycle or the issuance and acceptance of the 
Set Max Unlock command. When this command is accepted the device is in the Set_Max_Locked mode. The 
Set Max Unlock command changes the device from the Set_Max_Locked mode to the Set_Max_Unlocked 
mode. The Set Max Freeze Lock command allows the host to disable the Set Max commands (including Set 
Max UNLOCK) until the next power cycle. When this command is accepted the device is in the Set_Max_Frozen 
mode. 


The IDENTIFY DEVICE response word 83, bit 8 indicates that this extension is supported if set, and word 86, bit 
8 indicate the Set Max security extension enabled if set. 
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9.8 Write Cache Function 


Write cache is a performance enhancement whereby the device reports as completing the write command 
(Write Sector(s), Write Multiple and Write DMA) to the host as soon as the device has received all of the data 
into its buffer. And the device assumes responsibility to write the data subsequently onto the disk. 


e While writing data after completed acknowledgment of a write command, soft reset or hard reset does not 
affect its operation. But power off terminates writing operation immediately and unwritten data are to be lost. 


e Soft reset, Standby (Immediate) command and Flush Cache commands during writing the cached data are 
executed after the completion of writing to media. So the host system can confirm the completion of write 
cache operation by issuing Soft reset, Standby (Immediate) command or Flush Cache command to the 
device before power off. 


9.9 — Reassign Function 
The reassign Function is used with read commands and write commands. The sectors of data for reassignment 
are prepared as the spare data sector. 


This reassignment information is registered internally, and the information is available right after completing the 
reassign function. Also the information is used on the next power on reset or hard reset. 


If the number of the spare sector reaches 0 sectors, the reassign function will be disabled automatically. 
The spare tracks for reassignment are located at regular intervals from Cylinder 0. As a result of reassignment, 
the physical location of logically sequenced sectors will be dispersed. 


9.9.1 Auto Reassign Function 


The sectors those show some errors may be reallocated automatically when specific conditions are met. The 
spare tracks for reallocation are located at regular intervals from Cylinder 0. The conditions for auto-reallocation 
are described below. 


Non recovered write errors 


When a write operation can not be completed after the Error Recovery Procedure (ERP) is fully carried out, the 
sector(s) are reallocated to the spare location. An error is reported to the host system only when the write cache 
is disabled and the auto reallocation is failed. 


If the write cache function is ENABLED, and when the number of available spare sectors reaches 0 sectors, 
both auto reassign function and write cache function are disabled automatically. 


Non recovered read errors 


When a read operation is failed after defined ERP is fully carried out, a hard error is reported to the host system. 
This location is registered internally as a candidate for the reallocation. When a registered location is specified 
as a target of a write operation, a sequence of media verification is performed automatically. When the result of 
this verification meets the criteria, this sector is reallocated. 


Recovered read errors 


When a read operation for a sector failed once then recovered at the specific ERP step, this sector of data is 
reallocated automatically. A media verification sequence may be run prior to the relocation according to the 
pre-defined conditions. 
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9.10 Power-up in Standby feature set 


Power-Up In Standby feature set allows devices to be powered-up into the Standby power management state to 
minimize inrush current at power-up and to allow the host to sequence the spin-up of devices. 


This feature set will be enabled/disabled via the SET FEATURES command or use of jumper. When enabled by 
a jumper, the feature set shall not be disabled via the SET FEATURES command. The enabling of this feature 
set shall be persistent after power cycle. 


A device needs a SET FEATURES subcommand to spin-up to active state when the device has powered-up into 
Standby. The device remains in Standby until the SET FEATURES subcommand is received. 


If power-up into Standby is enabled, when an IDENTIFY DEVICE is received while the device is in Standby as a 
result of powering up into Standby, the device shall set word O bit 2 to one to indicate that the response is 
incomplete, then only words 0 and 2 are correctly reported. 


The IDENTIFY DEVICE information indicates the states as follows: 


identify device information is complete or incomplete 

this feature set is implemented 

this feature set is enabled or disabled 

the device needs the Set Features command to spin-up into active state 


9.11 Advanced Power Management feature set (APM) 


This feature allows the host to select an advanced power management level. The advanced power management 
level is a scale from the lowest power consumption setting of OLh to the maximum performance level of FEh. 
Device performance may increase with increasing advanced power management levels. Device power 
consumption may increase with increasing advanced power management levels. The advanced power 
management levels contain discrete bands, described in the section of Set Feature command in detail. This 
feature set uses the following functions: 


1. A SET FEATURES subcommand to enable Advanced Power Management 
2. ASET FEATURES subcommand to disable Advanced Power Management 


Advanced Power Management is independent of the Standby timer setting. If both Advanced Power 
Management and the Standby timer are set, the device will go to the Standby state when the timer times out or 
the device’s Advanced Power Management algorithm indicates that the Standby state should be entered. 


The IDENTIFY DEVICE response word 83, bit 3 indicates that Advanced Power Management feature is 
supported if set. Word 86, bit 3 indicates that Advanced Power Management is enabled if set. Word 91, bits 7-0 
contain the current Advanced Power Management level if Advanced Power Management is enabled. 


Hitachi hard disk drive specifications 
63 


9.12 48-bit Address Feature Set 


The 48-bit Address feature set allows devices with capacities up to 281,474,976,710,655 sectors. This allows 
device capacity up to 144,115,188,075,855,360 bytes. In addition, the number of sectors that may be transferred 
by a single command are increased by increasing the allowable sector count to 16 bits. 


Commands unique to the 48-bit Address feature set are: 
= Flush Cache Ext 

= Read DMA Ext 

= Read FPDMA Queued 

= Read Multiple Ext 

= Read Native Max Address Ext 
= — Read Sector(s) Ext 

= — Read Verify Sector(s) Ext 

= Set Max Address Ext 

= Write DMA Ext 

= Write DMA FUA Ext 

= Write FPDMA Queued 

= Write Multiple Ext 

= Write Multiple FUA Ext 

= Write Sector(s) Ext 

= Write Uncorrectable Ext 


The 48-bit Address feature set operates in LBA addressing only. Devices also implement commands using 
28-bit addressing, and 28-bit and 48-bit commands may be intermixed. 


In a device, the Features, the Sector Count, the Sector Number, the Cylinder High, and the Cylinder Low 
registers are a two-byte-deep FIFO. Each time one of these registers is written, the new content written is placed 
into the "most recently written" location and the previous content is moved to "previous content" location. 


The host may read the "previous content" of the Features, the Sector Count, the Sector Number, the Cylinder 
High, and the Cylinder Low registers by first setting the High Order Bit (HOB, bit 7) of the Device control register 
to one and then reading the desired register. If HOB in the Device Control register is cleared to zero, the host 
reads the "most recently written" content when the register is read. A write to any Command Block register shall 
cause the device to clear the HOB bit to zero in the Device Control register. The "most recently written" content 
always gets written by a register write regardless of the state of HOB in the Device Control register. 


Support of the 48-bit Address feature set is indicated in the Identify Device response bit 10 word 83. In addition, 
the maximum user LBA address accessible by 48-bit addressable commands is contained in Identify Device 
response words 100 through 103. 


When the 48-bit Address feature set is implemented, the native maximum address is the value returned by a 
Read Native Max Address Ext command. If the native maximum address is equal to or less than 268,435,455, a 
Read Native Max Address shall return the native maximum address. If the native maximum address is greater 
than 268,435,455, a Read Native Max Address shall return a value of 268,435,455. 
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9.13 Streaming feature Set 


The Streaming feature set is an optional feature set that allows a host to request delivery of data from a 
contiguous logical block address range within an allotted time. This places a priority on time to access the data 
rather than the integrity of the data. Streaming feature set commands only support 48-bit addressing. 


A device that implements the Streaming feature set shall implement the following minimum set of commands: 
= Configure Stream 


= Read Stream PIO 
= Write Stream PIO 
= Read Stream DMA 
= Write Stream DMA 
= Read Log Ext 


Support of the Streaming feature set is indicated in Identify Device work 84 bit 4. 


Note that PIO versions of these commands limit the transfer rate (16.6 MB/s), provide no CRC protection, and 
limit status reporting as compared to a DMA implementation. 


9.13.1 Streaming commands 


The streaming commands are defined to be time critical data transfers rather than the standard data integrity 
critical commands. Each command shall be completed within the time specified in the Configure Stream 
command or in the streaming command itself in order to ensure the stream requirements of the AV type 
application. The device may execute background tasks as long as the Read Stream and Write Stream command 
execution time limits are still met. 


Using the Configure Stream command, the host may define the various stream properties including the default 
Command Completion Time Limit (CCTL) to assist the device in setting up its caching for best performance. If 
the host does not use a Configure Stream command, the device shall use the CCTL specified in each streaming 
command, and the time limit is effective for one time only. If the CCTL is not set by Configure Stream command, 
the operation of a streaming command with a zero CCTL is device vendor specific. If Stream ID is not set by a 
Configure Stream command, the device shall operate according to the Stream ID set by the streaming 
command. The operation is device vendor specific. 


The streaming commands may access any user LBA ona device. These commands may be interspersed with 
non-streaming commands, but there may be an impact on performance due to the unknown time required to 
complete the non-streaming commands. 


The streaming commands should be issued using a specified minimum number of sectors transferred per 
command, as specified in word 95 of the Identify Device response. The transfer length of a request should be 
a multiple of the minimum number of sectors per transfer. 


The host provided numeric stream identifier, Stream ID, may be used by the device to configure its resources to 
support the streaming requirements of the AV content. One Stream ID may be configured for each read and 
write operation with different command completion time limits be each Configure Stream command. 
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9.13.1.1 Urgent bit 


The Urgent bit in the Read Stream and Write Stream commands specifies that the command should be 
completed in the minimum possible time by the device and shall be completed within the specified Command 
Completion Time Limit. 


9.13.1.2 Flush to Disk bit 


The Flush to Disk bit in the Write Stream command specifies that all data for the specified stream shall be 
flushed to the media before posting command completion. If a host requests flushes at times other than the 
end of each Allocation Unit, streaming performance may be degraded. The Set Features command to 
enable/disable caching shall not affect caching for streaming commands. 


9.13.1.8 Not Sequential bit 


The Not Sequential bit specifies that the next read stream command with the same Stream ID may not be 
sequential in LBA space. This information helps the device with pre-fetching decisions. 


9.13.1.4 Read Continuous bit 


If the Read Continuous bit is set to one for the command, the device shall transfer the requested amount of data 
to the host within the Command Completion Time Limit even if an error occurs. The data sent to the host by 
the device in an error condition is vendor specific. 


9.13.1.5 Write Continuous bit 


If the Write Continuous bit is set to one for the command, and an error is encountered, the device shall complete 
the request without posting an error. If an error cannot be resolved within the Command Completion Time Limit, 
the erroneous section on the media may be unchanged or may contain undefined data. A future read of this 
area may not report an error, even though the data is erroneous. 


9.13.1.6 Handle Streaming Error bit 


The Handle Streaming Error bit specifies to the device that this command starts at the LBA of a recently reported 
error section, so the device may attempt to continue its corresponding error recovery sequence where it left off 
earlier. This mechanism allows the host to schedule error recovery and defect management for content critical 
data. 


9.13.2 Streaming Logs 


The Streaming Data Transfer feature set requires two error logs and one performance log. These logs are 
accessed via the Read Log Ext command; the information included in the error logs is volatile and is not 
maintained across power cycles, hard resets, or sleep. These error logs are 512 bytes in length and retain the 
last 31 errors that occurred during any Streaming Data transfer. 
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9.14 SATA BIST (Built-in Self Test) 


The device supports the following BIST modes, and begins operations when it receives BIST Activate FIS. 
F — Far End Analog Loopback. 
L — Far End Retimed Loopback 
T — Far End Transmit only 
A — ALIGN Bypass (valid only in combination with T bit) 


S — Bypass Scrambling (valid only in combination with T bit) 


9.15 SATA Interface Power Management 


The device supports both receiving host-initiated interface power management requests and initiating 
interface power management. The device initiates interface power management when the device enters its 
power saving mode whose power consumption is lower than Normal Idle mode. 


9.16 Software Setting Preservation 


When a device is enumerated, software will configure the device using SET FEATURES and other commands. 
These software settings are often preserved across software reset but not necessarily across hardware reset. 
In Parallel ATA, only commanded hardware resets can occur, thus legacy software only reprograms settings that 
are cleared for the particular type of reset it has issued. In Serial ATA, COMRESET is equivalent to hard reset 
and a non-commanded COMRESET may occur if there is an asynchronous loss of signal. Since COMRESET 
is equivalent to hardware reset, in the case of an asynchronous loss of signal some software settings may be 
lost without legacy software knowledge. In order to avoid losing important software settings without legacy 
driver knowledge, the software settings preservation ensures that the value of important software settings is 
maintained across a COMRESET. Software settings preservation may be enabled or disabled using SET 
FEATURES with a subcommand code of 06h. If a device supports software settings preservation, the feature 
shall be enabled by default. 


9.16.1 COMRESET Preservation Requirements 


The software settings that shall be preserved across COMRESET are listed below. The device is only required 
to preserve the indicated software setting if it supports the particular feature/command the setting is associated 
with. 
INITIALIZE DEVICE PARAMETERS: Device settings established with the INITIALIZE DEVICE 
PARAMETERS command. 


Power Management Feature Set Standby Timer: The Standby timer used in the Power Management 
feature set. 


Read/Write Stream Error Log: The Read Stream Error Log and Write Stream Error Logs (accessed using 
READ LOG EXT and WRITE LOG EXT). 


Security mode state: The security mode state established by Security Mode feature set commands (refer 
to section 6.13 of the ATA/6 specification). The device shall not transition to a different security mode state 
based on a COMRESET. For example, the device shall not transition from the SEC5: Unlocked / not 
Frozen state to state SEC4: Security enabled / Locked when a COMRESET occurs, instead the device shall 
remain in the SEC5: Unlocked / not Frozen state. 


SECURITY FREEZE LOCK: The Frozen mode setting established by the SECURITY FREEZE LOCK 
command. 


SECURITY UNLOCK: The unlock counter that is decremented as part of a failed SECURITY UNLOCK 
command attempt. 
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SET ADDRESS MAX (EXT): The maximum LBA specified in SET ADDRESS MAX or SET ADDRESS 
MAX EXT. 


SET FEATURES (Write Cache Enable/Disable): The write cache enable/disable setting established by the 
SET FEATURES command with subcommand code of 02h or 82h. 


SET FEATURES (Set Transfer Mode): PIO, Multiword, and UDMA transfer mode settings established by 
the SET FEATURES command with subcommand code of 03h. 


SET FEATURES (Advanced Power Management EnablelDisable): The advanced power management 
enable/disable setting established by the SET FEATURES command with subcommand code of 05h or 85h. 


The advanced power management level established in the Sector Count register when advanced power 
management is enabled (SET FEATURES subcommand code 05h) shall also be preserved. 


SET FEATURES (Read Look-Ahead): The read look-ahead enable/disable setting established by the SET 
FEATURES command with subcommand code of 55h or AAh. 


SET FEATURES (Reverting to Defaults): The reverting to power-on defaults enable/disable setting 
established by the SET FEATURES command with a subcommand code of CCh or 66h. 


SET MULTIPLE MODE: The block size established with the SET MULTIPLE MODE command. 
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9.17 SATA II Optional Features 


There are several optional features defined in SATA II. The following shows whether these features are 
supported or not. 


9.17.1 Asynchronous Signal Recovery 


The device supports asynchronous signal recovery defined in SATA II. 


9.17.2 Device Power Connector Pin 11 Definition 


SATA II specification defines that Pin 11 of the power segment of the device connector may be used to 
provide the host with an activity indication and disabling of staggered spin-up. The device does not support 
both usage of Pin 11. 


9.17.3 Phy Event Counters 


Phy Event Counters are an optional feature to obtain more information about Phy level events that occur on the 
interface. This information may aid designers and integrators in testing and evaluating the quality of the interface. 
A device indicates whether it supports the Phy event counters feature in IDENTIFY (PACKET) DEVICE Word 76, 
bit 10. The host determines the current values of Phy event counters by issuing the READ LOG EXT command 
with a log page of 11h. The counter values shall not be retained across power cycles. The counter values shall 
be preserved across COMRESET and software resets. 


The counters defined can be grouped into three basic categories: those that count events that occur during Data 
FIS transfers, those that count events that occur during non-Data FIS transfers, and events that are unrelated to 
FIS transfers. Counters related to events that occur during FIS transfers may count events related to 
host-to-device FIS transfers, device-to-host FIS transfers, or bi-directional FIS transfers. A counter that records 
bi-directional events is not required to be the sum of the counters that record the same events that occur on 
device-to-host FIS transfers and host-to-device FIS transfers. 


Implementations that support Phy event counters shall implement all mandatory counters, and may support any 
of the optional counters as shown in 0. Note that some counters may increment differently based on the speed 
at which non-Data FIS retries are performed by the host and device. Implementations may record CRC and 
non-CRC error events differently. For example, there is a strong likelihood that a disparity error may cause a 
CRC error. Thus, the disparity error may cause both the event counter that records non-CRC events and the 
event counter that records CRC events to be incremented for the same event. Another example implementation 
difference is how a missing EOF event is recorded; a missing EOF primitive may imply a bad CRC even though 
the CRC on the FIS may be correct. These examples illustrate that some Phy event counters are sensitive to the 
implementation of the counters themselves, and thus these implementation sensitive counters cannot be used 
as an absolute measure of interface quality between different implementations. 


9.17.3.1 Counter Reset Mechanisms 


There are two mechanisms by which the host can explicitly cause the Phy counters to be reset. 

The first mechanism is to issue a BIST Activate FIS to the device. Upon reception of a BIST Activate FIS the 
device shall reset all Phy event counters to their reset value. The second mechanism uses the READ LOG EXT 
command. When the device receives a READ LOG EXT command for log page 11h and bit 0 in the Features 
register is set to one, the device shall return the current counter values for the command and then reset all Phy 
event counter values. 
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9.17.3.2 Counter Identifiers 


Each counter begins with a 16-bit identifier. O defines the counter value for each identifier. Any unused counter 
slots in the log page should have a counter identifier value of Oh. 

Optional counters that are not implemented shall not be returned in log page 11h. A value of ‘0’ returned for a 
counter means that there have been no instances of that particular event. There is no required ordering for event 
counters within the log page; the order is arbitrary and selected by the device vendor. 


For all counter descriptions, ‘transmitted’ refers to items sent by the device to the host and ‘received’ refers to 
items received by the device from the host. 


Bits 14:12 of the counter identifier convey the number of significant bits that counter uses. All 
counter values consume a multiple of 16-bits. The valid values for bits 14:12 and the 
corresponding counter sizes are: 

1h 16-bit counter 

2h 32-bit counter 

3h 48-bit counter 

Ah 64-bit counter 


Any counter that has an identifier with bit 15 set to one is vendor specific. This creates a vendor specific range of 
counter identifiers from 8000h to FFFFh. Vendor specific counters shall observe the number of significant bits 
14:12 as defined above. 


Identifier Mandatory I Description 

(Bits 11:0) Optional 

000h Mandatory | No counter value; marks end of counters in the page 

001h Mandatory | Command failed and ICRC bit set to one in Error register 

002h Optional R_ERR response for Data FIS 

003h Optional Not supported (R_ERR response for Device-to-Host Data FIS) 

004h Optional Not supported (R ERR response for Host-to-Device Data FIS) 

005h Optional R ERR response for Non-data FIS 

006h Optional Not supported (R ERR response for Device-to-Host Non-data FIS) 

007h Optional Not supported (R ERR response for Host-to-Device Non-data FIS) 

008h Optional Not supported (Device-to-Host non-Data FIS retries) 

009h Optional Transitions from drive PhyRdy to drive PhyNRdy 

OOAh Mandatory | Signature Device-to-Host Register FISes sent due to a COMRESET 

OOBh Optional CRC errors within a Host-to-Device FIS 

OODh Optional Non-CRC errors within a Host-to-Device FIS 

OOEh Optional vr (R ERR response for Host-to-Device Data FIS due to CRC 

010h Optional Not supported (R_ERR response for Host-to-Device Data FIS due to 
non-CRC errors) 

012h Optional Not supported (R_ERR response for Host-to-Device Non-data FIS due to 
CRC errors) 

013h Optional Not supported (R_ERR response for Host-to-Device Non-data FIS due to 
non-CRC errors) 


Table 38 Phy Event Counter Identifiers 
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9.17.3.2.1 Counter Definitions 

The counter definitions in this section specify the events that a particular counter identifier 
represents. 

9.17.3.2.1.1 Identifier 000h 

There is no counter associated with identifier 000h. A counter identifier of 000h indicates that 
there are no additional counters in the log page. 

9.17.3.2.1.2 Identifier 001h 

The counter with identifier 001h returns the number of commands that returned an ending status 
with the ERR bit set to one in the Status register and the ICRC bit set to one in the Error register. 
9.17.3.2.1.3 Identifier 002h 


The counter with identifier 002h returns the sum of (the number of transmitted Device-to-Host 
Data FISes to which the host responded with R ERR») and (the number of received Host-to- 
Device Data FISes to which the device responded with R_LERRp). 


9.17.3.2.1.4 Identifier 005h 


The counter with identifier 005h returns the sum of (the number of transmitted Device-to-Host 
non-Data FISes to which the host responded with R ERR?) and (the number of received Host-to- 
Device non-Data FISes to which the device responded with R_ERRp). Retries of non-Data FISes 
are included in this count. 


9.17.3.2.1.5 Identifier 009h 


The counter with identifier 009h returns the number of times the device transitioned into the 
PHYRDY state from the PHYNRDY state, including but not limited to asynchronous signal events, 
power management events, and COMRESET events. If interface power management is enabled, 
then this counter may be incremented due to interface power management transitions. 


9.17.3.2.1.6 Identifier O0OAh 

The counter with identifier OOAh returns the number of transmitted Device-to-Host Register FISes 
with the device reset signature in response to a COMRESET, which were successfully followed by 
an R_OK from the host. 

9.17.3.2.1.7 Identifier OOBh 

The counter with identifier OOBh returns the number of received Host-to-Device FISes of all types 
(Data and non-Data) to which the device responded with R_ERRp due to CRC error. 

9.17.3.2.1.8 Identifier 00Dh 


The counter with identifier OODh returns the number of received Host-to-Device FlSes of all types 
(Data and non-Data) to which the devices responded with R ERRp for reasons other than CRC 
error. 
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9.17.3.3 READ LOG EXT Log Page 11h 


READ LOG EXT log page 11h is one page (512 bytes) in length. The first Dword of the log page contains 
information that applies to the rest of the log page. Software should continue to process counters until a counter 
identifier with value Oh is found or the entire page has been read. A counter identifier with value Oh indicates that 
the log page contains no more counter values past that point. Log page 11h is defined in Table 39. 


Byte 7 6 5 4 3 2 1 0 

0 Reserved 

1 Reserved 

2 Reserved 

3 Reserved 

n Mg 
Counter n Identifier 

n+1 

n+2 

na Counter n Value 

Counter 

n Length 

508 

509 Reserved 

510 

511 Data Structure Checksum 


Table 39 READ LOG EXT Log Page 11h data structure definition 


Counter n Identifier 
Phy event counter identifier that corresponds to Counter n Value. Specifies the particular event counter 
that is being reported. The Identifier is 16 bits in length. 
Valid identifiers are listed in Table 39. 


Counter n Value 
Value of the Phy event counter that corresponds to Counter n Identifier. The number of significant bits is 
determined by Counter n Identifier bits 14:12 (as defined in section 4.3.2). The length of Counter n Value 
shall always be a multiple of 16-bits. All counters are one-extended. For example, if a counter is only 
physically implemented as 8-bits when it reaches the maximum value of OxFF, it shall be one-extended to 
OxFFFF. The counter shall stop (and not wrap to zero) after reaching its maximum value. 


Counter n Length 
Size of the Phy event counter as defined by bits 14:12 of Counter n Identifier. 
The size of the Phy event counter shall be a multiple of 16-bits. 


Data Structure Checksum 
The data structure checksum is the 2’s complement of the sum of the first 511 bytes in the data structure. 
Each byte shall be added with unsigned arithmetic and overflow shall be ignored. The sum of all 512 
bytes of the data structure will be zero when the checksum is correct. 


Reserved All reserved fields shall be cleared to zero 
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9.18 SCT Command Transport feature Set 


9.18.1 Overview 


9.18.1.1 Introduction 


SMART Command Transport (SCT) is the method for the drive to receive commands using log page EOh and 
transporting data using log page E1h. These log pages are used as follows: 


Log page EOh Log Page Eth 
Write log page Issue Command Send Data to the drive 
Read log page Return Status Received Data from the drive 


Table 40 SCT Log Page and direction 


There are two ways to access the log pages: using SMART READ/WRITE LOG and READ/WRITE LOG EXT. 
Both sets of commands access the same log pages and provide the same capabilities. 


The log directory for log pages EOh and E1h should report a length of one. The length of log page E1h does not 
indicate the length of an SCT data transfer. 


If SMART is supported, but not enabled, the drive supports SMART READ/WRITE LOG for Log page EOh and 
Eth. 


If security is enabled and password has not been issued to unlock the device, all SCT commands will fail. 


9.18.1.2 Capability definition 


Capability Identification is performed by issuing Identify Device command. Word 206 of Identify Data is used to 
determine if SCT is enabled and which SCT Action Codes are supported. 


Word Description 

206 SCT Command set support 
15-12 Vendor Specific 
11-6 Reserved 
5 Action Code 5 (SCT Data Table) supported 
4 Action Code 4 (Features Control) supported 
3 Action Code 3 (Error Recovery Control) supported 
2 Action Code 2 (SCT Write Same) supported 
1 Obsolete 
0 SCT Feature Set supported (includes SCT status 


Table 41 Identify Device Information Word 206 
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9.18.1.3 SCT Command Nesting and intermingling with Standard commands 


In general, standard ATA commands can be intermingled with SCT Commands but SCT commands cannot be 
nested. SCT commands that do not require a follow-on data transfer operation never have an issue with being 
intermixed with any ATA commands or each other. SCT commands that do require data transfer, on the other 
hand, may not be nested; that is, if a key command that requires a data transfer is issued, all data transfer - to or 
from the host - must complete before another SCT command is issued. In most cases, however, ATA 
read/write commands may be inserted in between SCT data transfers, that is, between complete SMART Read 
Log/Write Log commands. Furthermore, any reset (power-on, software or hardware) will cause the SCT 
command to be aborted. 


9.18.1.4 Resets 


In an SCT command is executing, any reset including Soft Reset, Hard Reset, COMRESET, and Power-On 
Reset all cause the command to be terminated. This could result in partial command execution or data loss. 
There is no indication once the drive becomes ready that the previous command was terminated. 
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9.18.2 SCT Command Protocol 
9.18.2.1 Command Transport 


SCT Command Transport occurs when a 512-byte data packet (called "Key Sector”) is created and the written to 
SMART or extended log page EOh. The key sector specifies Action and Function Codes along with the 
parameters that are required to perform the action. 


9.18.2.1.1 Issue SCT Command Using SMART 


Command Block Output Registers 

Register 7|61514|3|12|1|0 
Feature D6h 

Sector Count O1h 

Sector Number EOh 

Cylinder Low 4Fh 
cylinderHigh | cn O 
Device/Head eile ule, Deels 
Command BOh 


Table 42 Output Registers of SCT Command Using SMART 


Command Block Input Registers (Success) Command Block Input Registers (Error) 
Register 7|615141|3|2|11|0 Register 7|6151413|2|11|0 
Error 00h Error 04h 
Sector Count Depends on command Sector Count Extended Status code 
(LSB) (LSB) 
Sector Number Depends on command Sector Number Extended Status code 
(MSB) (MSB) 
Cylinder Low Number of sectors to Cylinder Low Number of sectors to 
transfer (LSB) transfer (LSB) 
Cylinder High Number of sectors to Cylinder High Number of sectors to 
transfer (MSB) transfer (MSB) 
Device/Head -}|-]-]- ]-]-]- | - | IDevice/Head -}-]-]-]-]-]-]- 
Status 50h Status 51h 


Table 43 Input Registers of SCT Command Using SMART 
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9.18.2.1.2 Issue SCT Command Using Write Log Ext 


Command Block Output Registers 


Register 7|6151413|/2|11|0 


Feature Current Reserved 
Previous Reserved 
Sector Count |Current O1h 
Previous 00h 
LBA Low Current EOh 
Previous Reserved 
LBA Mid Current 00h 
Previous 00h 
LBA High Current Reserved 
Previous Reserved 
Device/Head -|-]/-]|]D]-]-]-]- 
Command 3Fh 


Command Block Input Registers (Success) 


Table 44 Input Registers of SCT Command Using Write Log Ext 


Command Block Input Registers (Error) 


Register 7|6151413|2|11|0 | Register 7|615141312|11|0 
Error 00h Error 04h 
Sector Count |HOB=0 Depends on command Sector Count |HOB=0 Extended Status Code 
(LSB) (LSB) 
HOB=1 Reserved HOB=1 Reserved 
LBA Low HOB=0 Depends on command LBA Low HOB=0 Extended Status Code 
(MSB) (MSB) 
HOB=1 Reserved HOB=1 Reserved 
LBA Mid HOB=0 | Number of sectors (LSB) | |LBA Mid HOB=0 | Number of sectors (LSB) 
HOB=1 Reserved HOB=1 Reserved 
LBA High HOB=0 | Number of sectors (MSB) | |LBA High HOB=0 | Number of sectors (MSB) 
HOB=1 Reserved HOB=1 Reserved 
Device/Head -|-]-]-]-]- ]- |- | Device/Head -f-f-f-];-]-]-]- 
Status 50h Status 51h 


All ATA “previous” registers are reserved in Write Log Ext responses. 


Table 45 Output Registers of SCT Command Using Write Log Ext 
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9.18.2.1.3 Key Sector Format 


An SCT command (Key Sector) is always 512 bytes long. Table below shows the generic format of an SCT 
command. 


Byte Field Words Description 

1:0 Action Code 1 This field defines the command type and 
generally specifies the type of data being 
accessed, such as sector or physical action 
being performed, such as seek. 

3:2 Function Code 1 This field specifies the type of access, and 
varies by command. For example, this can 
specify read, write, verify, etc. 


X:4 Parameter1 Depends on command Depends on command 
Y:x+1 | Parameter2 Depends on command Depends on command 
Total Words 256 


Table 46 Key Sector Format 


The action codes are defined in Table below. 


Action Code Block Data | TF Data Description 

0000h - - Reserved 

0001h Read/Write Y Long Sector Access (Not Supported) 
0002h Write N SCT Write Same 

0003h - Y Error Recovery Control 

0004h - Y Features Control 

0005h Read N SCT Data Table 

0006h-BFFFh - - Reserved 

CO00h-FFFFh - - Vendor Specific 


Table 47 SCT Action Code List 
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9.18.2.1.4 Extended Status Code 


Status Code Definition 

0000h Command complete without error 

0001 Invalid Function Code 

0002h Input LBA out of range 

0003h Request sector count overflow. The number of sectors requested to transfer 
(Sector Count register) in the read or write log command is larger than required 
by SCT command. 

0004h Invalid Function code in Error Recovery command 

0005h Invalid Selection code in Error Recovery command 

0006h Host read command timer is less than minimum value 

0007h Host write command timer is less than minimum value 

0008h Background SCT command was aborted because of an interrupting host 
command 

0009h Background SCT command was terminated because of unrecoverable error 

OOOAh Invalid Function code in Long Sector Access command 

OOOBh SCT data transfer command was issued without first issuing an SCT command 

000Ch Invalid Function code in Feature Control command 

000D Invalid Feature code In Feature Control comman 

OOOEh Invalid New State value in Feature Control command 

OOOFh Invalid Option Flags in Feature Control command 

0010h Invalid SCT Action code 

0011 Invalid Table ID (table not supporte 

0012h Command was aborted due to drive security being locked 

0013h Invalid revision code 

0017h Blocking SCT Write Same command was terminated because of unrecoverable 
error 

0018h-BFFFh Reserved 

CO00h-C002h Vendor Specific 

CO03h Overlay switch failure in Long Sector Access command 

CO04h Read Long failure 

CO05h Write Long failure 

COO06h Write Cache enable failure 

C007h-FFEFh Vendor Specific 

FFFOh-FFFEh Reserve 

FFFFh SCT command executing in background 


Table 48 Extended Status Code 
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9.18.2.2 Data transfer 


Once an SCT command has been issued, status can be checked and data can be transferred. Data transfer 
uses log page E1h. 


9.18.2.2.1 Read/Write SCT Data Using SMART 


Command Block Output Registers 

Register 7|6151413|/2|11|0 

Feature D5h(Read)/D6h(Write) 

Sector Count Number of sectors to be 
transferred 

Sector Number E1h 

Cylinder Low 4Fh 

Cylinder High C2h 

Device/Head «1-|1-1ID|-|-|-|- 

Command BOh 


Table 49 Input Registers of SCT Data Transfer Using SMART 


9.18.2.2.2 Read/Write SCT Data Using Read/Write Log Ext 


Command Block Output Registers 
Register 7|615141312|11|0 
Feature Current Reserved 
Previous Reserved 
Sector Count |Current O1h 
Previous 00h 
LBA Low Current Eih 
Previous Reserved 
LBA Mid Current 00h 
Previous 00h 
LBA High Current Reserved 
Previous Reserved 
Device/Head -}|-]/-]D]-]-]-]- 
Command 2Fh(Read)/3Fh(Write) 


Table 50 Input Registers of SCT Data Transfer using Read/Write Log Ext 
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9.18.2.3 SCT Status Request 


Once an SCT command has been issued, a status is reported in the ATA registers. This status indicates that the 
command was accepted or that an error occurred. This ATA status return does not indicate successful 
completion of the SCT actions. Some commands can take several minutes or even hours to execute. In this 
case, the host can determine execution progress by requesting SCT status. 


Log page EOh contains the status information. Reading log page EOh retrieves the status information. The SCT 
status may be acquired any time that the host is allowing to send a command to the device. This command will 
not change the power state of the drive, nor terminate any background activity, including any SCT command in 
progress. 


9.18.2.3.1 SCT Status Request Using SMART 


Command Block Output Registers 

Feature D5h 

Sector Count O1h 

Sector Number EOh 

Cylinder Low 4Fh 

Cylinder High C2h 
Device/Head Jo Nee) ode Di kte eet | slice 
Command BOh 


Table 51 Intput Registers of SCT Status Request Using SMART 


9.18.2.3.2 SCT Status Request Using Read Log Ext 


Command Block Output Registers 
Register 7|6151413|2|11|0 
Feature Current Reserved 
Previous Reserved 
Sector Count |Current O1h 
Previous 00h 
LBA Low Current EOh 
Previous Reserved 
LBA Mid Current 00h 
Previous 00h 
LBA High Current Reserved 
Previous Reserved 
Device/Head -|-]-]D]-]-]-]- 
Command 2Fh 


Table 52 Input Registers of SCT Status Request Using Read Log Ext 
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9.18.2.3.3 Format of SCT Status Response 


Byte Type Field Name Value | Description 

1:0 Word Format Version 0003h | Status Response format version number 

3:2 Word SCT Version Manufacturers vendor specific implementation 
version number 

5:4 Word SCT Spec. 0001h | Highest level of SCT Technical Report supported 

9:6 DWord Status Flags Bit 0 : Segment Initialized Flag 

If this bit is set to 1, an SCT Write Same command 
write to all LBAs of the drive has completed without 
error. This bit shall be cleared to 0 when any user 
LBA is written, even if write cache is enabled. This 
bit is alse cleared if the capacity of the drive is 
changed via SETMAX, SETMAX EXT or DCO. This 
bit is preserved through a power cycle. 

Bit 1-31 : Reserved 

10 Byte Drive Status 0 = Active waiting for a command 
1 = Stand-by 
2 = Sleep 
3 = DST executing in background 
4 = SMART ODC executing in background 
5 = SCT executing in background 

13:11 Byte[3] reserved 00h 

15:14 Word Extended Status Status Of last SCT command Issued. FFFFh if SCT 

Code command executing in background. 

17:16 Word Action Code Action code of last SCT command issued. If the 
Extended Status Code is FFFFh, this is the Action 
Code of the command that is current executing. 

19:18 Word Function Code Function code of last SCT command issued. If the 
Extended Status Code is FFFFh, this is the Function 
Code of the command that is current executing. 

39:20 Byte[20 reserved OOh 

47:40 QWord LBA Current LBA of SCT command executin in 
background. If there is no command currently 
executing in the background, this field is undefined. 

199:48 | Byte[152 OOh 

200 Byte HDA Temp Current HDA temperature in degrees Celsius. This 
is a 2's complement number. 80h indicates that this 
value is invalid. 

201 Byte Min Temp Minimum HDA temperature In degrees Celsius. This 
is a 2's complement integer. 80h indicates that this 
value is invalid. 

202 Byte Max Temp Maximum HDA temperature In degrees Celsius. 
This is a 2's complement number. 80h indicates that 
this value is invalid. 

203 Byte Life Min Temp Minimum HDA temperature in degrees Celsius seen 
for the life of the device. This is a 2's complement 
integer. 80h indicates that this value is invalid. 

204 Byte Life Max Temp Maximum HDA temperature in degrees Celsius 
seen for the life of the drive. This is a 2’s 
complement number. 80h indicates that this value is 
invalid. 

205 Byte Reserved 00h 

209:206 | Dword Over Limit Count Number of temperature recording Intervals since the 
last power-on reset where the recorded temperature 
was greater than Max Op Limit. See table 93 for 
information about this Interval. 

213:210 | Dword Under Limit Number of temperature recording Intervals since the 

Count last power-on reset where the recorded temperature 
was less than Min Op Limit. See table 93 for 
information about this Interval. 

479:214 | Byte[275] | Reserved OOh 

511:480 | Byte[32 Vendor Specific 00 


Table 53 Data Format of SCT Status Response 
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9.18.3 SCT Command Set 


9.18.3.1 SCT Write Same (action code : 0002h) 
Inputs: (Key Sector) 


Word Name Value Description 


0 Action Code 0002h This action writes a pattern or sector of data repeatedly to 
the media. This capability could also be referred to as “Write 
All’ or "Write Same”. 


1 Function Code 0001h Repeat Write Pattern (Background Operation) 
0002h Repeat Write Sector (Background Operation) 
0101h Repeat Write Pattern (Blocking Operation) 
0102h Repeat Write Sector (Blocking Operation) 
5:2 Start LBA QWord First LBA 
9:6 Count QWord Number of sectors to fill 
11:10 Pattern DWord If the Function Code is 0001h, this field contains a 32-bit 


pattern that is written on the media starting at the location 
specified in words two through five 


255:12 reserved 0000h 
Table 54 SCT Write Same (Inputs) 


Outputs: (TF Data) 


Command Block Input Registers (Success) 

Error 00h 

Sector Count Reserved 

Sector Number Reserved 

Cylinder Low Number of sectors to transfer (LSB) = 01h 
Cylinder High Number of sectors to transfer (MSB) = 00h 
Device/Head Reserved 

Status 50h 


Table 55 SCT Write Same (Outputs) 


The SCT Write Same command will begin writing sectors from Start LBA in incrementing order until Count 
sectors have been written. A Count of zero means apply operation from Start LBA until the last user LBA on the 
drive is reached. The HPA feature determines the last user LBA. This command will not write over a hidden 
partition when hidden partitions are enabled using the Host Protected Area drive capabilities. Automatic sector 
reassignment is permitted during the operation of this function. 


If Start LBA or Start LBA + Count go beyond the last user LBA then an error is reported and the SCT command 
is not executed. Issuing this command with a value of zero for Start LBA and Count will cause all LBAs of the 
drive to be written the specified pattern. 


Once the key sector has been issued, if the Function Code was 0002h or 0102h and the TF Data indicates that 
the drive is ready to receive data, log page E1h should be written to transfer the data. 
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This command can change the Segment Initialized Flag. If the command writes all the user addressable sectors 
and completes without encountering an error or being aborted, then the "Segment Initialized Flag” (bit 0 of the 
Status Flags in the SCT Status. See0) shall be set to 1. A write to any user addressable sector on the drive 
(except another complete write all), shall cause the Segment Initialized Flag to be cleared. Reallocations as a 
result of reading data (foreground or background) do not clear the Segment Initialized Flag. 


Implementation note for Background Operation (Function code = 0001h, 0002h) 


In this mode, the drive will return command completion status when the drive finished receiving data. 


Any command, including IDENTIFY DEVICE, other than SCT Status, issued to the drive while this command is 
in progress will terminate the SCT Write Same command. The incoming command is executed. 


Use the SCT Status command to retrieve status information about the current SCT command. Example status 
information includes: command active or complete, current LBA, and errors. When this command is in progress, 
the SCT status error code will be FFFFh, and set to 0000h if the command completes without error. It will be less 
than FFFFh and grater the 0000h if the command terminated prematurely for any reason. 


Possible Extended Status Code for Background Operation (Function code = 0001h, 0002h) 


0008h Background SCT command was aborted because of an interrupting host command 


0009h Background SCT command was terminated because of unrecoverable error 


FFFFh SCT command executing in background 


Implementation note for Blocking Operation (Function code = 0101h, 0102h) 


In this mode, the drive will return command completion status when the drive finished the SCT Write Same 
operation. 


Outputs for Error 


Command Block Input Registers (Error) 

Register 7|6151413|2|11|0 

Error 04h 

Sector Count Extended Status code 
(LSB) 

Sector Number Extended Status code 
(MSB) 

Cylinder Low N/A 

Cylinder High N/A 

Device/Head -}-]-]-]-]-]-]- 

Status 51h 


Possible Extended Status Code for Blocking Operation (Function code = 0101h, 0102h) 


0017h Blocking SCT Write Same command was terminated because of unrecoverable 
error 
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9.18.3.2 Error Recovery Control command (action code : 0003h) 


Inputs: (Key Sector) 


Word Name Value Description 
0 Action Code 0003h Set the read and write error recovery time 
1 Function Code 0001h Set New Value 
0002h Return Current Value 
2 Selection Code 0001h Read Timer 
0002h Write Timer 
3 Value Word If the function code is 0001h, then this field contains the 
recovery time limit in 100ms units. The minimum SCT 
timeout value is 65 (=6.5 second). When the specified time 
limit is shorter than 6.5 second,the issued command is 
aborted. 
255:4 reserved 0000h 


Table 56 Error Recovery Control command (Inputs) 


Outputs: (TF Data) 


Command Block Input Registers (Success) 

Error 00h 

Sector Count If Function Code was 0002h, then this is the LSB of the requested recovery limit. 
Otherwise, this field is reserved. 

Sector Number If Function Code was 0002h, then this is the MSB of the requested recovery limit. 
Otherwise, this field is reserved. 

Cylinder Low reserved 

Cylinder High reserved 

Device/Head reserved 

Status 50h 


Table 57 Error Recovery Control command (Onputs) 


The Error Recovery Control command can be used to set time limits for read and write error recovery. For 
non-queued commands, these timers apply to command completion at the host interface. For queued 
commands where in order data delivery is enabled, these timers begin counting when the device begins to 
execute the command, not when the command is sent to the device. These timers do not apply to streaming 
commands, or to queued commands when out-of-order data delivery is enabled. 


These command timers are volatile. The default value is 0 (i.e. disable command time-out). 
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9.18.3.3 Feature Control Command (action code : 0004h) 
Inputs: (Key Sector) 


Word Name Value Description 
0 Action Code 0004h Set or return the state of drive features described in 0 
1 Function Code 0001h Set state for a feature 
0002h Return the current state of a feature 
0003h Return feature option flags 
2 Feature Code Word See 0 for a list of the feature codes 
3 State Word Feature code dependent value 
4 Option Flags Word Bit15:1 = Reserved 


If the function code is 0001h, setting bit 0 to one causes the 
requested feature state change to be preserved across 
power cycles. 


If the function code is 0001h, setting bit 0 to zero causes the 
requested feature state change to be volatile. A hard reset 
causes the drive to revert to default, or last non-volatile 
setting. 


255:5 reserved 0000h 


Table 58 Feature Control command (Inputs) 


Outputs: (TF Data) 
Command Block Input Registers (Success) 


Error O0h 


Sector Count If Function Code was 0002h, then this is the LSB of Feature State. 
If Function Code was 0003h, then this is the LSB of Option Flags. 
Otherwise, this field is reserved. 


Sector Number If Function Code was 0002h, then this is the MSB of Feature State. 
If Function Code was 0003h, then this is the MSB of Option Flags. 
Otherwise, this field is reserved. 


Cylinder Low reserved 
Cylinder High reserved 
Device/Head reserved 
Status 50h 


Table 59 Feature Control command (Outputs) 
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Feature Code 


State Definition 


0001h 


0001h : Allow write cache operation to be determined by Set Feature command 
0002h : Force write cache enabled 


0003h : Force write cache disabled 


If State 0001h is selected, the ATA Set Feature command will determine the operation 
state of write cache. If State 0002h or 0003h is selected, write cache will be forced into 
the corresponding operation state, regardless of the current ATA Set Feature state. 
Any attempt to change the write cache setting through Set Feature shall be accepted, 
but otherwise ignored, and not affect the operation state of write cache and complete 
normally without reporting an error. 


In all cases, bit 5 of word 85 in the Identify Device information will reflect the true 
operation state of write cache, one indicating enabled and zero indicating disabled. 


The default state is 0001h. 


0002h 0001h : Enable Write Cache Reordering 

0002h : Disable Write Cache Reordering 

The default state is 0001h. 

The drive does not return error for setting state 0002h, but the state is ignored. 
0003h Set time interval for temperature logging. 


0000h is invalid. 
0001h to FFFFh logging interval in minutes. 


This value applies to the Absolute HDA Temperature History queue. Issuing this 
command will cause the queue to be reset and any prior values in the queue will be 
lost. Queue Index shall be set to zero and the first queue location will be set to the 
current value. All remaining queue locations are set to 80h. The Sample Period, Max 
Op Limit, Over Limit, Min Op Limit and Under Limit values are preserved. 


Default value is 0001h. 


0004h-CFFFh 


Reserved 


DO00h-FFFFh 


Vendor Specific 


Table 60 Feature Code List 
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9.18.3.4 SCT Data Table Command (action code : 0005h) 
Inputs: (Key Sector) 
Word Name Value Description 
0 Action Code 0005h Read a data table 
1 Function Code 0001h Read Table 
2 Table ID Word See 0 for a list of data tables 
255:2 reserved 0000h 


Table 61 SCT Data Table command (Inputs) 


Outputs: (TF Data) 


Command Block Input Registers (Success) 

Error 00h 

Sector Count reserved 

Sector Number reserved 

Cylinder Low Number of sectors to transfer (LSB) = 01h 
Cylinder High Number of sectors to transfer (MSB) = 00h 
Device/Head reserved 

Status 50h 


Table 62 SCT Data Table command (Outputs) 


Table ID Description 

0000h Invalid 

0001h Reserved 

0002h HDA Temperature History Table (in absolute degree C). See 0 
0003h-CFFFh Reserved 

DOOOh-FFFFh Vendor Specific 


Table 63 Table ID 
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Byte 


Size 


Field Name 


Description 


1:0 


Word 


Format 
Version 


Data table format version (=0002h) 


3:2 


Word 


Sampling 
Period 


Absolute HDA Temperature sampling period 
in minutes. 


0000h indicates sampling is disabled. 


5:4 


Word 


Interval 


Timer interval between entries in the history 
queue. 


Byte 


Max Op Limit 


Maximum recommended continuous 
operating temperature. This is a one byte 2’s 
complement number that allows a range 
from -127°C to +127°C to be specified. 80h 
is an invalid value. This is a fixed value. 


Byte 


Over Limit 


Maximum temperature limit. This is a one 
byte 2’s complement number that allows a 
range from -127°C to +127°C to be 
specified. 80h is an invalid value. This is a 
fixed value. 


Byte 


Byte 


Min Op Limit 


Under Limit 


Minimum recommended continuous 
operating limit. This is a one byte 2’s 
complement number that allows a range 
from -127°C to +127°C to be specified. 80h 
is an invalid value. This is a fixed value. 


Minimum temperature limit. This is a one 
byte 2’s complement number that allows a 
range from -127°C to +127°C to be 
specified. 80h is an invalid value. This is a 
fixed value. 


29:10 


Byte[20] 


Reserved 


31:30 


Word 


Queue Size 


Number of entry locations in history queue. 


This value is 128. 


33:32 


Word 


Queue Index 


Last updated entry in queue. Queue Index is 
zero-based, so Queue Index 0000h is the 
first location in the buffer (at offset 34). The 
most recent temperature entered in the 
buffer is at Queue Index + 34. 


See Note 1 and Note 2. 


Table 64 Data Format of HDA Absolute Temperature History Table 


88 


Hitachi hard disk drive specifications 


(Queue 
Size+33):34 


511:(Queue Size 
+34) 


Byte[Queue Size] 


Byte[512-Queue 
Size-34] 


Queue Buffer 


Reserved 


This is a circular buffer of absolute HDA 
Temperature values. These are one byte 2’s 
complement numbers, which allow a range 
from -127°C to +127°C to be specified. A 
value of 80h indicates an initial value or a 
discontinuity in temperature recording. 


The Actual time between samples may vary 
because commands may not be interrupted. 
The sampling period is the minimum time 
between samples. See Not 1. 


If the host changes the logging interval using 
the volatile option, the interval between 
entries in the queue may change between 


power cycles with no indication to the host. 


Note 1 — The Absolute HDA Temperature History is preserved across power cycles with the requirement 
that when the drive powers up, a new entry is made in the history queue of 80h, an invalid absolute 
temperature value. This way an application viewing the history can see the discontinuity in temperature 
result from the drive being turned off. 


Note 2 — When the Absolute HDA Temperature history is cleared, for new drives or after changing the 
Logging Interval, the Queue Index shall be set to zero and the first queue location shall be set to the 
current Absolute HDA Temperature value. All remaining queue locations are set to 80h. 


Table 65 Data Format of HDA Absolute Temperature History Table —Continued-- 
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9.19 Extended Power Conditions (EPC) feature 


The Extended Power Conditions feature set provides a host with additional methods to control the power 
condition of a device. 


Subcommand code 4Ah enables, disables, and configures the use of the Extended Power Conditions feature 
set. If the EPC feature is not supported, then the device shall return command aborted Table 66. describes the 
EPC subcommands and describes the power condition IDs Table 66 Extended Power Conditions Subcommands 


EPC Subcommand Description 
Oh | Restore Power Condition Settings 
1h | Go To Power Condition 
2h | Set Power Condition Timer 
3h | Set Power Condition State 
4h ... Fh | Reserved 


Table 66 Extended Power Conditions Subcommands 


Power Condition ID Power Condition Name Description 
OOh | Standby z Standby 
O1h | Standby y Low RPM Standby 
02h...80h Reserved 
81h | Idle å Not support 
82h | Idle b Active idle 
83h | Idle c Low power idle 
84h ... FEN Reserved 
FFh | All Not support 


Table 67 Power Condition IDs 


9.19.1 Power conditions 


Idle_b, and Idle c are power conditions within the PM1:Ildle power management state. Standby_y and 
Standby_z are power conditions within the PM2:Standby power management state. The power conditions shall 
be ordered from highest power consumption (i.e., shortest recovery time) to lowest power consumption (i.e., 
longest recovery time) as follows: 


Idle_b power >= Idle_c power >= Standby_y power >= Standby_z power 
Each of these power conditions has a set of current, saved and default settings. Default settings are not 


modifiable. Default and saved settings shall persist across power cycles. The current settings shall not persist 
across power cycles. 
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9.19.2 Power condition timers 


The device shall have manufacturer specified power-on default settings for the power condition timers. Power 
condition timers are changeable with the SET FEATURES Extended Power Conditions subcommand. Extended 
Power Conditions doesn't become Enable as long as Timer is not adjusted to an effective value by using the 
subcommand of EPC. When all Timer is zero, EPC becomes Disable.Configured settings for the timers shall be 
readable in the Power Conditions log. 

A power condition timer set to zero indicates that the associated power condition is disabled. Power becomes 
Enable at the value whose timer is larger than ZERO. 

The IDENTIFY DEVICE command indicates if this feature set is supported Word 119 bit7, and if there are power 
condition timers enabled Word120 bit 7. 


If the EPC is enabled, then the value of each timer specifies the time after command completion that 
the device shall wait before transitioning to the power condition . All enabled power condition timers run 
concurrently . 


As a result of processing any command, the device may change to a different power condition. 


When an enabled timer expires, the device shall transition to the power condition associated with that timer. 
Timer expirations shall only cause the device to transition from higher power conditions to lower power 
conditions (e.g., if the Standby z timer is set to a smaller interval than the Idle b timer, and the device is 
currently in the Standby_z power condition, then the device shall remain in the Standby_z power condition when 
the Idle_b timer expires). If the timer expiration qualifies the device to transition to more than one enabled power 
condition, then the device shall transition to the power condition with the least power consumption. 


9.19.3 Interaction with resets, commands and other features 


On successful processing of a power cycle, the device shall: 

When EPC is Enable, the following content is executed. 

1) copy the Saved Timer Settings to the Current Timer Settings, for all supported power Conditions. 
2) reinitialize and restart all enabled EPC timers with Current values. 


On successful processing of a hardware reset, a software reset, or a DEVICE RESET command, the device 
shall: 

When EPC is Enable, the following content is executed. 

1) remain in the current power condition. 

2) reinitialize and restart all enabled EPC timers with Current values. 


The Extended Power Conditions and the Advanced Power Management features are mutually exclusive of each 
other. All EPC subcommands shall return command aborted if APM is enabled. The SET FEATURES 
Enable/Disable APM subcommands shall abort if IDENTIFY DEVICE data word 120 bit 7 is set to one. 


CheckPowerMode returns the same result as EPC NotSupport. 


During background activities, all EPC timers may be paused. On completion of the activity, any paused EPC 
timers shall be continued from where they were paused. 
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10 Command Protocol 


The commands are grouped into different classes according to the protocols followed for command execution. 
The command classes with their associated protocols are defined below. 


Please refer to Serial ATA Revision 1.0a (Section 9. device command layer protocol) and Serial ATA Il: 
Extensions to Serial ATA 1.0a (Section 4. Command layer) about each protocol. 


For all commands, the host must first check if BSY=1, and should proceed no further unless and until BSY=0. 
For all commands, the host must also wait for RDY=1 before proceeding. 


A device must maintain either BSY=1 or DRQ=1 at all times until the command is completed. The INTRQ signal 
is used by the device to signal most, but not all, times when the BSY bit is changed from 1 to 0 during command 
execution. 


A command shall only be interrupted with a COMRESET or software reset. The result of writing to the Command 
register while BSY=1 or DRQ=1 is unpredictable and may result in data corruption. A command should only be 
interrupted by a reset at times when the host thinks there may be a problem, such as a device that is no longer 
responding. 


Interrupts are cleared when the host reads the Status Register, issues a reset, or writes to the Command 
Register. 


The device timeout values are described in the Section12 on the page 250. 


10.1 PIO Data In commands 


These commands are: 


Device Configuration Identify 
Identify Device 

Read Buffer 

Read Log Ext 

Read Multiple 

Read Multiple Ext 

Read Sector(s) 

Read Sector(s) Ext 

Read Stream PIO 

SMART Read Attribute Values 
SMART Read Attribute Thresholds 
SMART Read Log Sector 


Execution includes the transfer of one or more 512 byte sectors of data from the device to the host. 


10.2 PIO Data Out commands 


These commands are: 


Device Configuration Set 
Download Microcode 

Format Track 

Security Disable Password 
Security Erase Unit 

Security Set Password 

Security Unlock 

Set Max Set Password command 
Set Max Unlock command 
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SMART Write Log Sector 
Write Buffer 

Write Log Ext 

Write Multiple 

Write Multiple Ext 

Write Multiple FUA Ext 
Write Sector(s) 

Write Sector(s) Ext 

Write Stream PIO 


Execution includes the transfer of one or more 512 byte sectors of data from the host to the device. 


10.3 Non-Data commands 


These commands are: 


Check Power Mode 

Configure Stream 

Device Configuration Freeze Lock 
Device Configuration Restore 
Execute Device Diagnostic 

Flush Cache 

Flush Cache Ext 

Idle 

Idle Immediate 

Initialize Device Parameters 

NOP 

Read Native Max Address 

Read Native Max Address Ext 
Read Verify Sector(s) 

Read Verify Sector(s) Ext 
Recalibrate 

Security Erase Prepare 

Security Freeze Lock 

Seek 

Set Features 

Set Max Address 

Set Max Address Ext 

Set Max Lock command 

Set Max Freeze Lock command 
Set Multiple Mode 

Sleep 

SMART Disable Operations 
SMART Enable/Disable Attribute Autosave 
SMART Enable Operations 
SMART Execute Off-line Data Collection 
SMART Return Status 

SMART Save Attribute Values 
SMART Enable/Disable Automatic Off-Line 
Standby 

Standby Immediate 

Write Uncorrectable Ext 


Execution of these commands involves no data transfer. 
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10.4 DMA Data In commands and DMA Data Out commands 


These commands are: 


Read DMA 

Read DMA Ext 
Read Stream DMA 
Write DMA 

Write DMA Ext 
Write DMA FUA Ext 
Write Stream DMA 


Execution of this class of command includes the transfer of one or more blocks of data between the device and 
the host using DMA transfer. 


10.5 First-party DMA commands 


These commands are: 
e Read FPDMA Queued 
e Write FPDMA Queued 


Execution of this class of commands includes command queuing and the transfer of one or more blocks of data 
between the device and the host. The protocol is described in the section 4.2 “Native Command Queuing” of 
“Serial ATA II: Extensions to Serial ATA 1.0a”. 


Host knowledge of I/O priority may be transmitted to the device as part of the command. There are two priority 
classes for NCQ command as high priority, the host is requesting a better quality of service for that command 
than the commands issued with normal priority. 


The classes are forms of soft priority. The device may choose to complete a normal priority command before an 
outstanding high priority command, although preference shallbe given to the high priority commands. The 
priority class is indicated in bit 7 (Priority Information) in the Sector Count register for NCQ commands (READ 
FPDMA QUEUED and WRITE FPDMA QUEUED). This bit can indicate either the normal priority or high priority 
class. If a command is marked by the host as high priority, the device shall attempt to provide better quality of 
service for the command. It is not required that devices process all high priority requests before satisfying 
normal priority requests. 
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11 Command Descriptions 


Binary Code Bit 
Protocol Command 


Check Power Mode 

Check Power Mode* 
Configure Stream 

Device Configuration Restore 
Device Configuration Freeze Lock 
Device Configuration Identify 
Device Configuration Set 
Download Microcode 
Execute Device Diagnostic 
Flush Cache 

Flush Cache Ext 

Format Track 

Identify Device 

Idle 

Idle* 

Idle Immediate 

Idle Immediate* 

Initialize Device Parameters 
Read Buffer 

Read DMA 

Read DMA 

Read DMA Ext 

Read FPDMA Queued 
Read Log Ext 

Read Multiple 

Read Multiple Ext 

Read Native Max Address 
Read Native Max Address Ext 
Read Sector(s) 

Read Sector(s) 

Read Sector(s) Ext 

Read Stream DMA 

Read Stream PIO 

Read Verify Sector(s) 

Read Verify Sector(s) 

Read Verify Sector(s) Ext 
Recalibrate 

Security Disable Password 
Security Erase Prepare 
Security Erase Unit 
Security Freeze Lock 
Security Set Password 
Security Unlock 


Table 68 Command Set 


N 
A 
(25) 


OOLkkKkOOD!/0000OO0OKLKkOOKLKkODOLKRKOKODOCOKLKOLKOKOKLKODOKLKOOLDOOJOOCDOCOCBLNRN 


kKkpbRkKbKOOOOOGOOOCOOKLHOKOOOKLHKHKRRKRKPRKKKOKKKKKKKKOKKP 
PPRPPRPRPORPRPRPODODODCOORPORPORORRRPOORORRBRRBRRODCOOCCOR ORDO 
PRPRPPRPRPODOORPRPRPRPRPRPRPRPORRPRPOOROORPORRORPROORRRPRBROOR!UH 
PRPRPRPRPRPFPODDDOCDODOOOROCDODOODODOCOORBRORODCOROORRBRRBREBPEHERBPEBERO 

CODDORP:!: 0OoOOKBKKOOOOKLKKLKkOKkOOKKkOOOOOOKLKOKOOOOOOOOKLKO 

KOOOKK!BHbOOKKOOOKkOOOKOOGOOOOOOKLHKHOOKHKOKkOOOOCOOO|R 
CRRPORPO!: OKkO0O0DOKLKkOKkOKLKOKOKKkOOKKKKKOOOKkOOKKKKKkOKLJO 


3 
3 
3 
3 
3 
1 
2 
2 
3 
3 
3 
2 
1 
3 
3 
3 
3 
3 
1 
4 
4 
4 
5 
1 
1 
1 
3 
3 
1 
1 
1 
4 
4 
3 
3 
3 
3 
2 
3 
2 
3 
2 
2 
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Protocol 


OPRABANNNNNNNAAAPHPANWWWWWNWWRPRPWWWWWW WWW WwW WwW 


Command 


Binary Code 
Bit 


(Hex) |7 6 5 4 3 2 1 0 
Seek 7X (0) 1 1 1 - - - - 
Set Features EF 1 1 1 0 1 1 1 1 
Set Max Address F9 1 1 1 1 1 0 0 1 
Set Max Address Ext 37 0 0 1 1 0 1 1 1 
Set Multiple Mode C6 1 1 0 0 0 1 1 0 
Sleep E6 1 1 1 0 O0 1 1 0 
Sleep* 99 1 0 O 1 1 0 0 1 
SMART Disable Operations BO 1 0 1 1 0 0 0 0 
SMART Enable/Disable Attribute Auto save BO 1 0 1 1 0 0 (0) 0 
SMART Enable Operations BO 1 0 1 1 0 0 0 0 
SMART Execute Off-line Data Collection BO 1 0 1 1 0 0 0 0 
SMART Read Attribute Values BO 1 0 1 1 0 (0) 0 0 
SMART Read Attribute Thresholds BO 1 0 1 1 (0) 0 0 0 
SMART Return Status BO 1 0 1 1 0 0 0 0 
SMART Save Attribute Values BO 1 0 1 1 (0) 0 0 0 
SMART Write Log Sector BO 1 0 1 1 0 0 0 0 
SMART Enable/Disable Automatic Off-line BO 1 0 1 1 (0) (0) 0 0 
Standby E2 1 1 1 0 0 O 1 0 
Standby* 96 1 0 O 1 0 1 1 0 
Standby Immediate EO 1 1 1 0 0 0 0 0 
Standby Immediate* 94 1 0 0 1 0 1 0 0 
Write Buffer E8 1 1 1 0 1 (0) 0 0 
Write DMA CA 1 1 0 0 1 0 1 0 
Write DMA CB 1 1 0 0 1 0 1 1 
Write DMA Ext 35 0 0 1 1 0 1 0 1 
Write DMA FUA Ext 3D o 0 1 1 1 1 0 1 
Write FPDMA Queued 61 0 1 1 0 0 0 0 1 
Write Log Ext 3F o 0 1 1 1 1 1 1 
Write Multiple C5 1 1 0 0 0 1 0 1 
Write Multiple Ext 39 0 0 1 1 1 0 0 1 
Write Multiple FUA Ext CE 1 1 0 0 1 1 1 0 
Write Sector(s) 30 0 0 1 1 0 0 0 0 
Write Sector(s) 31 0 0 1 1 0 0 0 1 
Write Sector(s) Ext 34 0 0 1 1 0 1 0 0 
Write Stream DMA 3A 0 0 1 1 1 0 1 0 
Write Stream PIO 3B 0 0 1 1 1 0 1 1 
Write Uncorrectable Ext 45 0 1 0 0 0 1 0 1 


Protocol : 


1 PIO data IN command 

2: PIO data OUT command 
3: Non data command 

4: DMA command 

5 

+ Vendor specific command 


Table 69 Command Set --Continued-- 


Commands marked * are alternate command codes for previous defined commands. 
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Command code Feature 
Command (Subcommand) (Hex) Register 
(Hex) 


(SMART Function) 
SMART Read Attribute Values BO DO 
SMART Read Attribute Thresholds BO D1 
SMART Enable/Disable Attribute Autosave BO D2 
SMART Save Attribute Values BO D3 
SMART Execute Off-line Data Collection BO D4 
SMART Read Log BO D5 
SMART Write Log BO D6 
SMART Enable Operations BO D8 
SMART Disable Operations BO D9 
SMART Return Status BO DA 
SMART Enable/Disable Automatic Off-line BO DB 
(Set Features) 
Enable Write Cache EF 02 
Set Transfer Mode EF 03 
Enable Advanced Power Management EF 05 
Enable Power-up in Standby Feature Set EF 06 
Power-up in Standby Feature Set Device Spin-up EF 07 
Disable read look-ahead feature EF 55 
Disable reverting to power on defaults EF 66 
Disable write cache EF 82 
Disable Advanced Power Management EF 85 
Disable Power-up in Standby Feature Set EF 86 
Enable read look-ahead feature EF AA 
Enable reverting to power on defaults EF CC 


Table 70 Command Set (Subcommand) 


Table 68 Command Set on the page 95 and Table 69 Command Set --Continued-- on the page 96 show 
the commands that are supported by the device. Table 70 Command Set (Subcommand) on the page 97 shows 
the sub-commands they are supported by each command or feature. 
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The following symbols are used in the command descriptions: 


Output Registers 


0 
1 
D 


x 


Indicates that the bit must be set to 0. 

Indicates that the bit must be set to 1. 

The device number bit. Indicates that the device number bit of the Device/Head Register should be 
specified. This bit is reserved since all Serial ATA devices behave like Device 0. 


Head number. Indicates that the head number part of the Device/Head Register is an output parameter 
and should be specified. 


LBA mode. Indicates the addressing mode. Zero specifies CHS mode and one does LBA addressing 
mode. 


Retry. Original meaning is already obsoleted, there is no difference between O and 1. (Using 0 is 
recommended for future compatibility.) 


Option Bit. Indicates that the Option Bit of the Sector Count Register should be specified. (This bit is used 
by Set Max ADDRESS command) 

Valid. Indicates that the bit is part of an output parameter and should be specified. 

Indicates that the hex character is not used. 

Indicates that the bit is not used. 


Input Registers 


0 
1 
H 


V 


Indicates that the bit is always set to 0. 

Indicates that the bit is always set to 1. 

Head number. Indicates that the head number part of the Device/Head Register is an input parameter and 
will be set by the device. 

Valid. Indicates that the bit is part of an input parameter and will be set to 0 or 1 by the device. 

Indicates that the bit is not part of an input parameter. 


The command descriptions show the contents of the Status and Error Registers after the device has completed 
processing the command and has interrupted the host. 


Please refer to ATA interface specifications about other commands’ descriptions which are not described in this 
SATA interface specification. However, be careful that Serial ATA Device/Head register bit-4 (d) is different 
from that of Parallel ATA. In Serial ATA, Device/Head register bit-4 is reserved for all commands. 
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11.1 Check Power Mode (E5h/98h) 


Command Block Output Registers 
Register 7 6 5 4 3 2 10 


Data 


Command Block Input Registers 


Feature 


Sector Count 


Cylinder Low 
Cylinder High 


Ps Gel p 
1 1 


Command 1 0 O 1 O0 1 


7 6 5 4 3 2 1 0 
CRC | UNC | O |TIDN| O | ABT | TON | AMN 


Table 71 Check Power Mode Command (E5h/98h) 


Status ... See Below... 


Status Register 


7 6 5 4 3 2 1 0 
BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 
V V 


The Check Power Mode command will report whether the device is spun up and the media is available for 
immediate access. 


Input Parameters From The Device 


Sector Count The power mode code. The command returns O in the Sector Count Register if the 
device is in Standby or Sleep mode. Otherwise, the Sector Count Register will be set to 
OFFh. 
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11.2 Configure Stream (51h) 


Command Block Output Registers Command Block Input Registers 
easter reppe] kose peppe 
NE 
Fy) ERR fe» — HHT 
cane Ere Ivy Fv fee 
mi. 
SR ee MH 
EE el St rae eae 
owen TEE ETT DT sector umber MOBO} LI 
Previous | - | - | - | -|-|-[- | - | PROB ) a a | a] 


re ae ced ce led ea el Pep rpm cre Fd el el ed 
å [previous [= [= [= [-[-[-]-[-] [7 


| Hop=1 | - | -|-|-[-|-]-[- | 
rinaervnn (Guren LILL nesen oe ILL 


| Previous | - | - | -|-|-|-|-|-| | Hop=a | á pale akelas] 
Bornea pa p o EEE] fm FELTET 
conmans — — fofrfefifofefef] 


Error Register Status Register 


5 4 3 2 1 0 7 6 5 4 3 2 1 0 
CRC | UNC 0 IDN 0 ABT | TON | AMN BSY | RDY | SE | DSC | DRQ | COR | IDX | ERR 
V V V 


ENER 


Table 72 I Stream Command (5th) 


The Configure Stream command specifies the operating parameters of an individual stream. A Configure 
Stream command may be issued for each stream that is to be added or removed from the current operating 
configuration. If A/R = 1 and the specified ID is already valid at the device, the new parameters shall replace the 
old parameters, unless Command Abort is returned (See abort conditions for Error Register). In this case the old 
parameters for the specified Stream ID shall remain in effect. 


Abort conditions for Error register are the following. 


e The device does not support the Streaming Feature Set. 
e AIR is cleared to zero and the Feature field contains a Stream ID that has not been sent in a previous 
CONFIGURE STREAM command. 
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Output Parameters To The Device 
Feature Current bit 7 (AIR) 


Feature Current bit 6 (R/W) 


Feature Current bit 0..2 (Stream ID) 
Feature Previous 


Sector Count Current 


Sector Count Previous 


If set to one, a request to add a new stream. 
If cleared to zero, a request to remove a previous configured 
stream is specified. 
R/W specifies a read stream if cleared to zero and a write stream 
if set to one. 
The Stream ID shall be a value between 0 and 7. 
The default Command Completion Time Limit (CCTL). 
The value is calculated as follows: 

(Default CCTL) = ((content of the Features register)* 

(Identify Device words (99:98))) micriseconds. 

This time shall be used by the device when a streaming 
command with the same stream ID and a CCTL of zero are 
issued. The time is measured from the write of the command 
register to the final INTRQ for command completion. The device 
has minimum CCTL value. When the specified value is 
shorter than the minimum value, CCTL is set to the 
minimum value. Actual minimum CCTL value is described 
in the “Deviations from Standard” section. 
Allocation Unit Size In Sectors (7:0) 


Allocation Unit Size In Sectors (15:8) 
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11.3 Device Configuration Overlay (B1h) 


Command Block Output Registers Command Block Input Registers 
6 5 4 3 2 1 0 


Sector Count VV VV VV VV 


Sector Number |- - - = >] 


| cylinder Low | cylinder Low | vvvvvvvv| VV VV VV V 


Cylinder High pe Cylinder High VV VV VV VV 


Error Register Status Register 


e E CACAL AEA 


Table 73 Device Configuration Overlay Command (B1h) 


Individual Device Configuration Overlay feature set commands are identified by the value placed in the Features 
register. The table below shows these Features register values. 


DEVICE CONFIGURATION RESTORE 
DEVICE CONFIGURATION FREEZE LOCK 


DEVICE CONFIGURATION IDENTIFY 
DEVICE CONFIGURATION SET 


Table 74 Device Configuration Overlay Features register values 


11.3.1 Device Configuration Restore (Subcommand COh) 


The Device Configuration Restore command disables any setting previously made by a Device Configuration 
Set command and returns the content of the Identify Device or Identify Packet Device command response to the 
original settings as indicated by the data returned from the execution of a Device Configuration Identify 
command. 
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11.3.2 Device Configuration Freeze Lock (Subcommand C1h) 


The Device Configuration Freeze Lock command prevents accidental modification of the Device Configuration 
Overlay settings. After successful execution of a Device Configuration Freeze Lock command, all Device 
Configuration Set, Device Configuration Freeze Lock, Device Configuration Identify, and Device Configuration 
Restore commands are aborted by the device. The Device Configuration Freeze Lock condition shall be cleared 
by a power-down. The Device Configuration Freeze Lock condition shall not be cleared by hardware or software 
reset. 


11.3.3 Device Configuration Identify (Subcommand C2h) 


The Device Configuration Identify command returns a 512 byte data structure via PIO data-in transfer. The 
content of this data structure indicates the selectable commands, modes, and feature sets that the device is 
capable of supporting. If a Device Configuration Set command has been issued reducing the capabilities, the 
response to an Identify Device or Identify Packet Device command will reflect the reduced set of capabilities, 
while the Device Configuration Identify command will reflect the entire set of selectable capabilities. 


The format of the Device Configuration Overlay Data structure is shown on next page. 


11.3.4 Device Configuration Set (Subcommand C3h) 


The Device Configuration Set command allows a device manufacturer or a personal computer system 
manufacturer to reduce the set of optional commands, modes, or feature sets supported by a device as 
indicated by a Device Configuration Identify command. The Device Configuration Set command transfers an 
overlay that modifies some of the bits set in words 63, 82, 83, 84, and 88 of the Identify Device command 
response. When the bits in these words are cleared, the device no longer supports the indicated command, 
mode, or feature set. If a bit is set in the overlay transmitted by the device that is not set in the overlay received 
from a Device Configuration Identify command, no action is taken for that bit. 


The format of the overlay transmitted by the device is described in the table on next page. The restrictions on 
changing these bits are described in the text following that table. If any of the bit modification restrictions 
described are violated or any setting is changed with Device Configuration Set command, the device shall return 
command aborted. At that case, error reason code is returned to sector count register, invalid word location is 
returned to cylinder high register, and invalid bit location is returned to cylinder low register. The Definition of 
error information is shown on page 105. 


Error Information Example 1: 


After establish a protected area with Set Max address, if a user attempts to change maximum LBA address 
(Device Configuration Set or Device Configuration Restore), device shall abort that command and return error 
reason code as below. 


Cylinder high : 03h = word 3 is invalid 

Cylinder low : 00h this register is not assigned in this case 
Sector Number : 00h this register is not assigned in this case 
Sector count : O6h = Protected area is now established 


Error Information Example 2: 


When device is enabled the Security feature set, if user attempts to disable that feature, device abort that 
command and return error reason code as below. 


Cylinder high : 07h = word 7 is invalid 

Cylinder low : 00h = bit 8-15 are valid 

Sector Number : 08h = bit 3 is invalid 

Sector count : 04h = now Security feature set is enabled 
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Content 


[O0 [| 0002h 


1 Multiword DMA modes supported 
15-3 | Reserved 
2 | 1 = Multiword DMA mode 2 and below are supported 
1 | 1 = Multiword DMA mode 1 and below are supported 
0 | 1 = Multiword DMA mode 0 is supported 


Maximum LBA address 
Command set/feature set supported 


2 Ultra DMA modes supported 
15-7 | Reserved 
6 | 1 = Ultra DMA mode 6 and below are supported 

1 = Ultra DMA mode 5 and below are supported 
1 = Ultra DMA mode 4 and below are supported 
1 = Ultra DMA mode 3 and below are supported 
1 = Ultra DMA mode 2 and below are supported 
1 = Ultra DMA mode 1 and below are supported 
1 = Ultra DMA mode 0 is supported 

7 


15 | 0 = Reserved 
14 | 0 = Reserved 
13 | 0 = Reserved 
12 | 1 = SMART Selective self-test is supported 
11 | 1 = Forced Unit Access is supported 
10 | 0 = Reserved 
9 | 1 = Streaming feature set is supported 
8 | 1 = 48-bit Addressing feature set supported 
7 | 1= Host Protected Area feature set supported 
6 | 0 = Reserved 
5 | 1 = Read/Write DMA Queued commands supported 
4 | 1 = Power-up in Standby feature set supported 
3 | 1 = Security feature set supported 
2 | 1= SMART error log supported 
1 | 1 = SMART self-test supported 
0 | 1= SMART feature set supported 


8 Serial ATA command / feature sets Supported 
15-5 | Reserved 

4 | 1 = Supports software settings preservation 
3 | Reserved 
2 | 1= Supports interface power management 
1 
0 


1 = Supports non-zero buffer offset in DMA Setup FIS 
1 = Supports native command queuing 


9-20 Reserved 


21 15-14 | Reserved 
13 | 1 = Support for WRITE UNCORRECTABLE is allowed 
12-10 | Reserved 


9 | 1 = Extended Power Conditions feature set supported 


8-0 | Reserved 


22-254 Reserved 


255 Integrity word <Note .> 
15-8 Checksum 
7-0 Signature (A5h) 


Table 75 Device Configuration Overlay Data structure 
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Note. 


Bits 7:0 of this word contain the value A5h. Bits 15:8 of this word contain the data structure checksum. The data 
structure checksum is the two's complement of the sum of all byte in words O through 254 and the byte 
consisting of bits 7:0 of word 255. Each byte is added with unsigned arithmetic, and overflow is ignored. The 
sum of all bytes is zero when the checksum is correct. 


Cylinder high invalid word location 
Cylinder low invalid bit location (bits (15:8)) 
invalid bit location (bits (70) 


DCO feature is frozen 

Device is now Security Locked mode 

Device's feature is already modified with DCO 
User attempt to disable any feature enabled 
Device is now SET MAX Locked or Frozen mode 
Protected area is now established 

DCO is not supported 

Subcommand code is invalid 

other reason 


Table 76 DCO error information definition 
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11.4 Download Microcode (92h) 


Command Block Output Registers 


æ Jr 


SECTOR COUNT(08-15) 
Cylinder Low BUFFER OFFSET(00-07) 


Command Block Input Registers 


PE TETEN 
wn | 


eerie [oo 


Status Register 


7 6 5 4 3 2 1 
BSY | RDY | DF |DSC}DRQ|COR| IDX | ERR 


ESEESE 


Table 77 Download Microcode Command (92h) 


Output Parameters To The Device 
Feature Subcommand code. 
03h : Download and save microcode with offsets. 
07h : Download and save microcode. 
Other values are reserved. 
Sector Count Lower byte of 16-bit sector count value to transfer from the host. 
Sector Number Higher byte of 16-bit sector count value to transfer from the host. 


Cylinder Buffer offset (only used for Feature = 03h) 


This command enables the host to alter the device's microcode. The data transferred using the DOWNLOAD 
MICROCODE commands is vendor specific. 


All transfers shall be an integer multiple of the sector size. The size of the data transfer is determined by the 
contents of the Sector Number and Sector Count registers. The Sector Number register is used to extend the 
Sector Count register to create a 16-bit sector count value. The Sector Number register is the most significant 
eight bits and the Sector Count register is the least significant eight bits. A value of zero in both the Sector 
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Number and Sector Count registers shall indicate no data is to be transferred. 


ABT will be set to 1 in the Error Register if the value in the Feature register is neither 03h nor 07h, or the device 
is in Security Locked mode. When the reload of new microcode is requested in the data sent by the host for this 
Download command, UNC error will be set to 1 in the Error Register if the device fails to reload new microcode. 
This error is reported only when the reload of microcode is requested. 


In reloading new microcode, when the spin-up of the device is disabled, the device spins down after reloading 
new microcode. 


A Features register value of 03h indicates that the microcode will be transferred in two or more Download 
Microcode commands using the offset transfer method. The buffer offset value is defined by the value in 
Cylinder registers. The buffer offset value is the starting location in the microcode file, which varies in 512 byte 
increments. 


All microcode segments shall be sent to the device in sequence. 


The device may abort the DOWNLOAD MICROCODE command and discard all previously downloaded 
Microcode, if the current buffer offset is not equal to the sum of the previous DOWNLOAD MICROCODE 
command buffer offset and the previous sector count. The first DOWNLOAD MICROCODE command shall 
have a buffer offset of zero. 

The new firmware should become effective immediately after the transfer of the last data segment has 
completed. 


When the device detects the last download microcode command for the firmware download the device shall 
perform any device required verification and save the complete set of downloaded microcode. 


If the device receives a command other than download microcode prior to the receipt of the last segment the 
new command is executed and all previously downloaded microcode is discarded. 


If a software or hardware Reset is issued to the device before all of the microcode segments have been 
transferred to the device the device shall abandon all of the microcode segments received and process the 
Reset. 
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11.5 Execute Device Diagnostic (90h) 


Command Block Output Registers Command Block Input Registers 


ae ee | (eee 


Cylinder Low 
[ome [oe 


Error Register Status Register 


7 6 5 4 3 2 1 0 
Diagnostic Code BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


perejo 


Fore |- 3 0] 


Table 78 Execute Device Diagnostic Command (90h) 


The Execute Device Diagnostic command performs the internal diagnostic tests implemented by the device. The 
results of the test are stored in the Error Register. 


The normal Error Register bit definitions do not apply to this command. Instead, the register contains a 
diagnostic code. See Table 34 Diagnostic Codes” on the page 48 for its definition. 
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11.6 Flush Cache (E7h) 


Command Block Output Registers Command Block Input Registers 
Regster |7 6 5 43210 Register 7 65 4 3 2 10 


(Feature — |- ee Error ...See Below... 

mm | 

San 
Ee 
E 
HEER 


Sector Count re OE EE GE 


Sector Number | - - - - - - == 


Cylinder Low Cylinder Low o> BLE ot eS et a 
Cylinder High Cylinder High Bd me ike Å bd SE 


Device/Head 1 - 1 D - - - - Device/Head - eee 
| Command | 1 1 0 O 1 1 1 Status ... See Below... 


7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 
CRCIUNC| 0 IDN 0 | ABT | TON | AMN 


ae ee eee 


Table 79 Flush Cache Command (E7h) 


BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


imi ame 


This command causes the device to complete writing data from its cache. 
The device returns good status after data in the write cache is written to disk media. 
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11.7 Flush Cache Ext (EAh) 


Command Block Output Registers Command Block Input Registers 
reuse [rele revs ——_—(7[efs[e[sfelafo 
pæarow JP] paarow BT 
Data High BE Data High HANNENE 
owen EE 
Feature 
mme FEE 


cemer |-|-|-|- 
Sector Count 

evne |[-[-- 

cuert |-|-|-|-| 
Sector Number 

revne [= [- [=F 


ages 

Cylinder Low Cylinder Low 
[meme E 
RRE 

Cylinder High Cylinder High 


[DeviceHead | Device/Head 


ee 


Error Register Status Register 


CEAS EA E A 


Table 80 Flush Cache Ext Command (EAh) 


This command causes the device to complete writing data from its cache. 


The device returns good status after data in the write cache is written to disk media. 


Hitachi hard disk drive specifications 
110 


11.8 Format Track (50h) 


Command Block Output Registers 
Register 7 6 5 4 3 2 1 0 


Data 


Command Block Input Registers 


eed eee 
aron 


Status Register 


7 6 5 4 3 2 1 (0) 


Sector Count 


Sector Number |V V V V V V V V 


2 1 0 


ABT | TON | AMN BSY | RDY | DF |DSC | DRQ |COR| IDX | ERR 


Table 81 Format Track Command(50h) 


The Format Track command formats a single logical track on the device. Each good sector of data on the track 
will be initialized to zero with write operation. At this time, whether the sector of data is initialized correctly is not 
verified with read operation. Any data previously stored on the track will be lost. 


The host may transfer a sector of data containing a format table to the device. But the device ignores the format 
table and writes zero to all sectors on the track regardless of the descriptors. 


Since device performance is optimal at 1:1 interleave, and the device uses relative block addressing internally, 
the device will always format a track in the same way no matter what sector numbering is specified in the format 
table. 
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Output Parameters To The Device 


Sector Number 


Cylinder High/Low 


In LBA mode, this register specifies LBA address bits 0 - 7 to be formatted. (L=1) 
The cylinder number of the track to be formatted. (L=0) 


In LBA mode, this register specifies LBA address bits 8-15 (Low), 16-23 (High) to be 
formatted. (L=1) 


The head number of the track to be formatted. (L=0) 
In LBA mode, this register specifies LBA address bits 24-27 to be formatted. (L=1) 


Input Parameters From The Device 


Sector Number 
Cylinder High/Low 


H 
Error 


In LBA mode, this register specifies current LBA address bits 0-7. (L=1) 


In LBA mode, this register specifies current LBA address bits 8-15 (Low), 16-23 
(High) 

In LBA mode, this register specifies current LBA address bits 24-27. (L=1) 

The Error Register. An Abort error (ABT=1) will be returned when LBA out of range. 


In LBA mode, this command formats a single logical track including the specified LBA. 
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11.9 Format Unit (F7h) 


Command Block Input Registers 
Error ...See Below... 
mem | > 
MERETE 
ME 


Sector Count me? GN ee ENG OE 


Cylinder Low Dom he å LEN ee sår SE 


Cylinder Low 


Cylinder High 


Device/Head 1 L 1 OD - - - - Device/Head B eee 
Command | LIT BD Status ...See Below... 


Cylinder High - < 2 2 2 =- =- - 


7 6 5 4 3 
BSY | RDY | DF | DSC | DRQ | COR 


HON 


Table 82 Format Unit Command (F7h) 


The Format Unit command initializes all user data sectors after merging reassigned sector location into the 
defect information of the device and clearing the reassign information. Both new reassign information and new 
defect information are available right after command completion of this command. Previous information of 
reassign and defect are erased from the device by executing this command. 


Note that the Format Unit command initializes from LBA 0 to Native MAX LBA regardless of setting by Initialize 
Device Parameter (91h) command, Device Configuration Overlay, or Set Max Address (F9h) command, so the 
protected area defined by these commands is also initialized. 


Security Erase Prepare (F3h) commands should be completed just prior to the Format Unit command. If the 
device receives a Format Unit command without a prior Security Erase Prepare command, the device aborts the 
Format Unit command. 


All values in Feature register are reserved, and any values other than 11h should not be put into Feature 
register. 


This command does not request to data transfer. 


Command execution time depends on drive capacity. To determine command timeout value, Word 89 of Identify 
Device data should be referred. 
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11.10 Identify Device (ECh) 


Command Block Output Registers Command Block Input Registers 
Register 76543210 Register 7 65 4 3 2 10 


si! : i i i i i i i 
Error ...See Below... 
Sector Count 


Sector Count Sy pe - BS ew GE Sir te 


Sector Number | - - - - - - == 


Cylinder Low Cylinder Low 4 ee. See fe ce VE 
Cylinder High Cylinder High oe is. et Sh eR ee 


Device/Head 1 - 1 D - - - - Device/Head - eee 
} command |1 1 1 O 1 100 Status ...See Below... 


Error Register Status Register 


7 6 4 2 1 0 7 6 5 4 3 2 1 0 


5 
0 


CRC | UNC BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


Table 83 Identify Device Command (ECh) 


The Identify Device command requests the device to transfer configuration information to the host. The device 
will transfer a sector to the host containing the information described in the following pages. 
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Word Content Description 
00 045AH Drive classification, bit assignments: 
or 15 (=0): 1=ATAPI device, O=ATA device 
045EH 14-8: retired 
7 (=0): 1=removable cartridge device 
6 (=1): 1=fixed device 
5-3: retired 
2 (=0): Response incomplete 
1: retired 
0 (=0): Reserved 
01 XXXXH Number of cylinders in default translate mode 
02 C837H Specific Configuration 
37C8H: Need Set Feature for spin-up after power-up 
i Identify Device is incomplete 
r Need Set Feature for spin-up after power-up 
738CH: i ARE 
Identify Device is complete 
8C73H: No Need Set Feature for spin-up after power-up 
' Identify Device is incomplete 
, No Need Set Feature for spin-up after power-up 
C837H: : peer 
Identify Device is complete 
03 00xxH Number of heads in default translate mode 
04 0 Reserved 
05 0 Reserved 
06 003FH Number of sectors per track in default translate mode 
07 0000H Number of bytes of sector gap 
08 0000H Number of bytes in sync field 
09 0000H Reserved 
10-19 XXXX Serial number in ASCII (0 = not specified) 
20 0003H Controller type: 
0003: dual ported, multiple sector buffer with look-ahead read 
21 XXXXH Buffer size in 512-byte increments. In case of 64MB buffer, it is clipped to OxFFFF. 
22 0038H Number of ECC bytes for the device 
23-26 XXXX Microcode version in ASCII 
27-46 XXXX Model number in ASCII 
47 8010H 15-8: 80h 
. Maximum number of sectors that can be transferred per interrupt on Read 
7-0: i $ 
and Write Multiple commands 
48 4000H Trusted Computing feature set options 
15(=0): Shall be cleared to zero 
14(=1): Shall be set to one 
13-1(=0): Reserved for the Trusted Computing Group 
0(=0) : O=Trusted Computing feature set is not supported 
Table 84 Identify device information 
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Word Content Description 
49 xFOOH Capabilities, bit assignments: 
15-14 (=0) Reserved 
13 Standby timer 
(=1) values as specified in ATA standard are supported 
(=0) values are vendor specific 
12 (=0) Reserved 
11 (=1) IORDY Supported 
10 (=1) IORDY can be disabled 
9 (=1) LBA supported 
8 (=1) DMA supported 
7-0(=0) Reserved 
50 4000H Capabilities, bit assignments: 
15-14(=01) word 50 is valid 
13- 1 (=0) Reserved 
0 Minimum value of Standby timer 
(=0) less than 5 minutes 
51 0200H PIO data transfer cycle timing mode 
DMA data transfer cycle timing mode 
52 0200H Refer Word 62 and 63 
53 0007H Validity flag of the word 
15- 8(=0): Free-fall Control Sensitivity 
00h = Vendor's recommended setting 
7-3(=0): Reserved 
2(=1): 1=Word 88 is Valid 
1(=1): 1=Word 64-70 are Valid 
O(=1): 1=Word 54-58 are Valid 
54 xXxxH Number of current cylinders 
55 XXXXH Number of current heads 
56 XXXXH Number of current sectors per track 
Current capacity in sectors 
57-58 xxxxH Word 57 es the low word of the capacity 
59 OxxxH Current Multiple setting. bit assignments 
15-9 (=0) Reserved 
8 1= Multiple Sector Setting is Valid 
7-0 xxh= Current setting for number of sectors 
Total Number of User Addressable Sectors 
60-61 xxxxH Word 60 specifies the low word of the number 
FFFFFFFh=The 48-bit native max address is greater than 268,435,455 
62 0000H 
63 xx07H Multiword DMA Transfer Capability 
15- 8 Multi word DMA transfer mode active 
7-0(=7) Multi word DMA transfer modes supported 
(support mode 0,1 and 2) 
64 0003H Flow Control PIO Transfer Modes Supported 
15-8(=0) Reserved 
7-0 (=3) Advanced PIO Transfer Modes Supported 
'11' = PIO Mode 3 and 4 Supported 
65 0078H Minimum Multiword DMA Transfer Cycle Time Per Word 
15-0(=78) Cycle time in nanoseconds (120ns, 16.6MB/s) 
Table 85 Identify device information --Continued-- 


Hitachi hard disk drive specifications 
116 


Description 


66 


67 


68 


69-74 
75 


76 


77 


78 


79 


Table 86 


0078H Manufacturer's Recommended Multiword DMA Transfer Cycle Time 
15-0(=78) Cycle time in nanoseconds (120ns, 16.6MB/s) 
0078H Minimum PIO Transfer Cycle Time Without Flow Control 
15-0(=78) Cycle time in nanoseconds (120ns, 16.6MB/s) 
0078H Minimum PIO Transfer Cycle Time With IORDY Flow Control 
15- 0(=78) Cycle time in nanoseconds (120ns, 16.6MB/s) 
0000H Reserved 
001FH Queue depth 
15-5(=0) Reserved 
4-0(=1F) Maximum queued depth - 1 
170xH SATA capabilities 
15-13(=0) Reserved 
12(=1) High Priority command (Please see 6.5 First-party DMA commands) 
11(=0) Reserved 
10(=1) Phy event counters 
9(=1) Receipt of host-initiated interface power management requests 
8(=1) Native Command Queuing supported 
7-4(=0) Reserved 
3(=x) SATA Gen-3 speed (6.0Gbps) supported 
2(=x) SATA Gen-2 speed (3.0Gbps) supported 
1(=1) SATA Gen-1 speed (1.5Gbps) supported 
0(=0) Reserved 
000xH 15-4(=0) | Reserved 
3(=x) | Current negotiated SATA speed is Gen-3 of 6.0Gbps 
2(=x) | Current negotiated SATA speed is Gen-2 of 3.0Gbps 
1(=1) | Current negotiated SATA speed is Gen-1 of 1.5Gbps 
0(=0) | Reserved 
005EH SATA supported features 
15-7(=0) Reserved 
6(=1) Software setting preservation 
5(=0) Reserved 
4(=1) In-order data delivery 
3(=1) Device initiated interface power management 
2(=1) DMA Setup Auto-Activate optimization 
1(=1) Non-zero buffer offset in DMA Setup FIS 
0(=0) Reserved 
0040H SATA enabled features 
15-7(=0) Reserved 
6(=1) Software setting preservation 
5(=0) Reserved 
4(=0) —In-order data delivery 
3(=0) Device initiated interface power management 
2(=0) DMA Setup Auto-Activate optimization 
1(=0) Non-zero buffer offset in DMA Setup FIS 
0(=0) Reserved 


Identify device information --Continued— 
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Description 


80 01FCH Major version number 
ATA-2, ATA-3, ATA/ATAPI-4, ATA/ATAPI-5, ATA/ATAPI-6. ATA/ATAPI-7 


15-0(=1FCh) and ATA8-ACS 
81 0029H Minor version number 

15-0(=29h) ATA8-ACS Revision 4 
82 746BH Command 


15(=0) Reserved 
14 (=1) NOP command 
13 (=1) READ BUFFER command 
12 (=1) WRITE BUFFER command 
11 (=0) Reserved 
10 (=1) Host Protected Area Feature Set 
9 (=0) DEVICE RESET command 
8 (=0) SERVICE interrupt 
7 (=0) Release interrupt 
6 (=1) LOOK AHEAD 
5 (=1) WRITE CACHE 
4 (=0) PACKET Command feature set 
3(=1) Power management feature set 
2 (=0) Removable feature set 
1(=1) Security feature set 
0 (=1) SMART feature Set 


Table 87 Identify device information --Continued— 
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Word 
83 


84 


85 


Table 88 


Content Description 


7D69H 
15-14(=01) 
13 (=1) 

12 (=1) 

11 (=1) 

10 (=1) 

9 (=0) 

8 (=1) 

7 (=0) 


6 (=1) 


5 (=1) 
4 (=0) 
3 (=1) 
2 (=0) 
1 (=0) 
0 (=1) 
4163H 
or 15-14(=01) 
4773H 13(=0) 
12-11(= 0) 
10 (=x) 

9 (=x) 

8 (=1) 

7 (=0) 


6 (=1) 


5 (=1) 
4 (=x) 
3 (=0) 
2 (=0) 
1 (=1) 
0 (=1) 
XXXXH 
15 


ORPNWAUONWO 


Command set supported 


Word 83 is valid 

FLUSH CACHE EXT command supported 

FLUSH CACHE command supported 

Device Configuration Overlay command supported 
48-bit Address feature set supported 

Reserved 

SET Max Security extension 

Set Features Address Offset feature mode 

SET FEATURES subcommand required to spin-up 
after power-up 

Power-Up In Standby feature set supported 
Removable Media Status Notification feature 
Advanced Power Management feature set 

CFA feature set 

READ/WRITE DMA QUEUED 

DOWNLOAD MICROCODE command 


Command set/feature supported extension 


Word 84 is valid 

IDLE IMMEDIATE with UNLOAD FEATURE supported 

Reserved 

URG bit supported for WRITE STREAM DMA and WRITE STREAM PIO 
URG bit supported for READ STREAM DMA and READ STREAM PIO 
World wide name supported 

WRITE DMA QUEUED FUA EXT command supported 

WRITE DMA FUA EXT and WRITE MULTIPLE FUA EXT commands 
supported 

General Purpose Logging feature set supported 

Streaming feature set supported 

Media Card Pass Through Command feature set supported 

Media serial number supported 

SMART self-test supported 

SMART error logging supported 


Command set/feature enabled 


Reserved 

NOP command 

READ BUFFER command 
WRITE BUFFER command 
Reserved 

Host Protected Area feature set 
DEVICE RESET command 
SERVICE interrupt 

RELEASE interrupt 

LOOK AHEAD 

WRITE CACHE 

PACKET Command feature set 
Power management feature set 
Removable media feature set 
Security feature set 

SMART feature set 


Identify device information --Continued— 
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Table 89 


Word Content Description 
86 XXXXH Command set/feature enabled 
15 Words 120:119 are valid. 
14 Reserved 
13 FLUSH CACHE EXT command supported 
12 FLUSH CACHE command supported 
11 Device Configuration Overlay command enabled 
10 48-bit Address features set supported 
9 Reserved 
8 Set Max Security extensions enabled 
7 Set Features Address Offset mode 
6 Set Features subcommand required to spin-up 
after power-up 
5 Power-Up In Standby feature set enabled 
4 Removable Media Status Notification feature 
3 Advanced Power Management Feature set 
2 CFA Feature set 
1 READ/WRITE DMA QUEUED 
0 DOWNLOAD MICROCODE command 
87 4163H Command set/feature default 
pene 15-14(=01) Word 87 is valid 
or 13(=0) IDLE IMMEDIATE with UNLOAD FEATURE supported 
4773H 12-11(= 0) Reserved 
10 (=x) URG bit supported for WRITE STREAM DMA and WRITE STREAM PIO 
9 (=x) URG bit supported for READ STREAM DMA and READ STREAM PIO 
8 (=1) World wide name supported 
7 (=0) WRITE DMA QUEUED FUA EXT command supported 
6 (=1) WRITE DMA FUA EXT and WRITE MULTIPLE FUA EXT commands 
supported 
5 (=1) General Purpose Logging feature set supported 
4 (=x) Valid CONFIGURE STREAM command has been executed 
3 (=0) Media Card Pass Through Command feature set enabled 
2(=0) Media serial number is valid 
1(=1) SMART self-test supported 
0 (=1) SMART error logging supported 


Identify device information --Continued— 
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Word Content Description 
88 Ox7FH Ultra DMA Transfer modes 
15- 8(=xx) Current active Ultra DMA transfer mode 
15 Reserved (=0) 
14 Mode 6 1 = Active 0 = Not Active 
13 Mode 5 1 = Active 0 = Not Active 
12 Mode 4 1 = Active 0 = Not Active 
11 Mode 3 1 = Active 0 = Not Active 
10 Mode 2 1 = Active 0 = Not Active 
9 Mode 1 1 = Active 0 = Not Active 
8 Mode 0 1 = Active 0 = Not Active 
7- O(=7F) Ultra DMA transfer mode supported 
7 Reserved (=0) 
6 Mode 6 1 = Support 
5 Mode5 1 = Support 
4 Mode 4 1 = Support 
3 Mode 3 1 = Support 
2 Mode 2 1 = Support 
1 Model 1 = Support 
0 Mode 0 1 = Support 
89 EET Time required for security erase unit completion 
Time= value(xxxxh)*2 [minutes] 
90 0000H Time required for Enhanced security erase completion 
91 0000H Current Advanced power management value 
92 FFFEH Current Password Revision Code 
93 0000H COMRESET result 
Table 90 Identify device information --Continued— 
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Word 


Content 


Description 


94 


95 


96 


97 


98-99 


100-103 


104 


105-106 
107 


108-111 


112-118 
119 


120 


Table 91 


0000H 


XXXXH 


XXXXH 


XXXXH 


XXXXH 


XXXXH 


XXXXH 


0000H 
5A87H 


XXXXH 


0000H 
401Ch 


401Ch 


Reserved 

Stream Minimum Request Size 

Number of sectors that provides optimum performance in streaming environment. This number 

shall be a power of two, with a minimum of eight sectors (4096 bytes). The starting LBA value for| 

each streaming command should be evenly divisible by this request size. 

Streaming Transfer Time - DMA 

The worst-case sustainable transfer time per sector for the device is calculated as follows: 
Streaming Transfer Time = (word 96) * (words(99:98) / 65536) 

If the Streaming Feature set is not supported by the device, the content of word 96 shall be zero. 

Streaming Access Latency - DMA and PIO 

The worst-case access latency of the devoce for a streaming command is calculated as follows: 
Access Latency = (word 97) * (words(99:98) / 256) 

If the Streaming Feature set is not supported by the device, the content of word 97 shall be zero. 


Streaming Performance Granularity 
These words define the fixed unit of time that is used in Identify Device words (97:96) and 
(104),and Set Features subcommand 43h, and in the Streaming Performance Parameters log, 
which is accessed by use of the Read Log Ext command, and in the Command Completion 
Time Limit that is passed in streaming commands. The unit of time for this parameter shall be in 
microseconds, e.g. ad value of 10000 indicates 10 ms. 
Total Number of User Addressable Logical Sectors for 48-bit commands 
Streaming Transfer Time - PIO 
The worst-case sustainable transfer time per sector for the device is calculated as follows: 
Streaming Transfer Time = (word 104) * (words(99:98) / 65536) 
If the Streaming Feature set is not supported by the device, the content of word 104 shall be 
zero. 
Reserved 
Inter-seek delay for ISO-7779 acoustic testing in microseconds 
World wide name 
the optional value of the world wide name for the device 
Reserved 
Supported settings (Continued from word 84:82) 
15 Shall be cleared to zero 
14 Shall be set to one. 
13-8 Reserved 
1=Extended Power Conditions feature set is supported 
Reserved 
0=Free-fall Control feature set is not supported 
1=The segmented feature for download microcode is supported. 
1=The READ/ WRITE LOG DMA EXT commands are supported. 
1=Write Uncorrectable is supported. 
0=Write-Read-Verify feature set is not supported 
Reserved 
Command set/feature enabled/supported. (Continued from word 87:85) 
15 Shall be cleared to zero 
14 Shall be set to one. 
13-8 Reserved 
7 1=Extended Power Conditions feature set is enabled 
6 
5 
4 
3 
2 
1 
0 


OrRPNWHRUON 


Reserved 

0=Free-fall Control feature set is disabled 

1=The segmented feature for download microcode is supported. 
1=The READ/ WRITE LOG DMA EXT commands are supported. 
1=Write Uncorrectable is supported. 

0=Write-Read-Verify feature set is not enabled 

Reserved 


Identify device information --Continued— 
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Word Content Description 


121-126 0000H Reserved 
127 0000H Removable Media Status Notification feature set 
0000H=Not supported 
128 XXXXH Security status. Bit assignments 


15-9 Reserved 
8 Security Level 
7-6 Reserved 
Enhanced erase 
Expired 
Freeze 
Lock 
Enabled/Disable 
Capability 
129 XXXXH * | Current Set Feature Option. Bit assignments 
15-4 Reserved 
3 Auto reassign enabled 
2 Reverting enabled 
1 Read Look-ahead enabled 
0 Write Cache enabled 


OrRPNWAU 


130-159 XXXXH * | Reserved 


15-12 Vendor specific 
11-6 Reserved 

5 Action Code 5 (SCT Data Table) 

4 Action Code 4 (Features Control) 
Action Code 3 
(Error Recovery Control) 

2 Action Code 2 
(SCT Write Same) 
Action Code 1 
(Long Sector Access) 
SCT Feature Set 


1= Maximum, 0= High 


1= Support 
1= Expired 
1= Frozen 
1= Locked 
1= Enable 
1= Support 


1= Enable 
1= Enable 
1= Enable 
1= Enable 


160-167 0000H Reserved 
168 0002H 15-4| Reserved 
3-0| Device Nominal Form Factor | 02H shows 3.5inch nominal form factor 
169-175 0000H Reserved 
176-205 0000H Current media serial number (0000H=Not supported) 
206 SCT Command set support 


1= Support 
1= Support 


1= Support 
1= Support 


0= Not Support 


(includes SCT status) 1= Support 
Table 92 Identify device information --Continued— 
Note. The '* mark in 'Content' field indicates the use of those parameters are vendor specific. 
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Word Content Description 


207-208 0000H Reserved 
209 0000H Alignment of logical blocks within a larger physical block 
0000H=Not supported 
210-211 0000H Write-Read-Verify Sector Count Mode 3 (DWord) 
0000H=Not supported 
212-213 0000H Write-Read-Verify Sector Count Mode 2 (DWord) 
0000H=Not supported 
214 0000H NV Cache Capabilities 
0000H=Not supported 
215-216 0000H NV Cache Size in Logical Blocks (DWord) 
217 1C20H Nominal media rotation rate (=7200rpm) 
218 0000H Reserved 
219 0000H NV Cache Options 
0000H=Not supported 
220 0000H 15-8(=0) Reserved 
7-0(=0) Write-Read-Verify feature set current mode(not supported) 
221 0000H Reserved 
222 101FH Transport major version number 


15-12(=1) Transport Type (1= Serial) 
11-5(=0) Reserved 
4(=1) SATA Rev 2.6 
3(=1) SATA Rev 2.5 
2(=1) SATA II: Extensions 
1(=1) SATA 1.0a 
O(=1) ATA8-AST 


223 0021H Transport minor version number (ATA8-AST T13 Project D1697 Revision Ob) 
224-233 0000H Reserved 
Minimum number of 512-byte data blocks per DOWNLOAD MICROCODE command 
234 0001H formode 3 
Maximum number of 512-byte data blocks per DOWNLOAD MICROCODE command 
235 03E0H 
for mode 3 
236-254 0000H Reserved 
255 XASH 15-8 Checksum. This value is the two's complement of the sum of all bytes in byte O 


through 510 
7-0 (A5) Signature 


Table 93 Identify device information --Continued— 
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11.11 Idle (E3h/97h) 


Command Block Output Registers 


Register 7 6 5 4 3 2 


Command Block Input Registers 
7 6 5 4 3 210 


Data 


emi [oo 
mene [ 


Error Register 


emai | 
omen [ 
mmm [ 


Status Register 


7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 
CRCIUNC| 0 IDN 0 | ABT | TON | AMN BSY | RDY | DF |DSCI|DRQ|COR | IDX | ERR 
RR 


Table 94 Idle Command (E3h/97h) 


The Idle command causes the device to enter Idle mode immediately, and set auto power down timeout 
parameter (standby timer). And then the timer starts counting down. 


When the Idle mode is entered, the device is spun up to operating speed. If the device is already spinning, the 
spin up sequence is not executed. 


During Idle mode the device is spinning and ready to respond to host commands immediately. 


Hitachi hard disk drive specifications 
125 


Output Parameters To The Device 


Sector Count Timeout Parameter. If zero, then the automatic power down sequence is disabled. If 
non-zero, then the automatic power down sequence is enabled, and the timeout interval is 


shown below: 


Value Description 
0) Timer disabled 
1-240 Value * 5 
241-251 (Value-240) * 30 minutes 

252 21 minutes 
253 8 hours 
254 Aborted 
255 21 minutes 15 seconds 


When the automatic power down sequence is enabled, the drive will enter Standby mode 
automatically if the timeout interval expires with no drive access from the host. The timeout 
interval will be reinitialized if there is a drive access before the timeout interval expires. 
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11.12 Idle Immediate (E1h/95h) 


Command Block Output Registers Command Block Input Registers 
Register 7 6 5 4 3 2 10 Register 7 6 5 4 3 2 10 


Data Data a tier cee tt, Red yee? mar Se 


Feature Error ... See Below... 


Sector Count San wey ES SS 


Sector Number | - = = = = = = | Sector Number | - - - - - - - = 


Sector Count 


Cylinder Low Cylinder Low - ee eee 


Cylinder High Cylinder High ov curt, 9 OEP Re aes ee 


Device/Head Device/Head - eee 


Command 1 1 1 0000 1 Status ... See Below... 


Error Register 


7 6 5 4 3 
BSY | RDY | DF |DSC |DRQ|C 
ER aa ay EARRA 


Table 95 Idle Immediate Command (E1h/95h) 


The Idle Immediate command causes the device to enter Idle mode. 


The device is spun up to operating speed. If the device is already spinning, the spin up sequence is not 
executed. 


During Idle mode the device is spinning and ready to respond to host commands immediately. 


The Idle Immediate command will not affect to auto power down timeout parameter. 
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11.13 Initialize Device Parameters (91h) 


(ann CSR ee | a 
eee |e eee eer 
awe [ 
omme] 
ELLER 
SEENE 
E 


6 5 4 3 2 1 0 
ee] 
emer [| mm 
oa | om 


Error Register Status Register 


7 6 4 3 2 1 (0) 7 6 5 4 3 2 1 0 
ABT | TON | AMN BSY |RDY | DF |DSC|DRQ|COR | IDX | ERR 


Table 96 Initialize Device Parameters Command (91h) 


The Initialize Device Parameters command enables the host to set the number of sectors per track and the 
number of heads minus 1, per cylinder. Words 54-58 in Identify Device Information reflect these parameters. 


The parameters remain in effect until following events: 


° Another Initialize Device Parameters command is received. 
° The device is powered off. 
° Soft reset occurs and the Set Feature option of CCh is set instead of 66h. 


Output Parameters To The Device 


Sector Count The number of sectors per track. 0 does not mean there are 256 sectors per track, but 
there is no sector per track. 


H The number of heads minus 1 per cylinder. The minimum is 0 and the maximum is 15. 


Note: The following conditions needs to be satisfied to avoid invalid number of cylinders beyond FFFFh. 


(Total number of user addressable sectors)/((Sector Count)*(H+1)) = < FFFFh 


The total number of user addressable sectors is described in Identify Device command. 
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11.14 Read Buffer (E4h) 


Command Block Output Registers Command Block Input Registers 
Reger 76543210 Register 7 65 4 3 2 10 


oaa | KE i i : i i i i i 
fee fe på cos ees 


Sector Count Op se, ooh eS sår Se 


Sector Number | - - - - - - == 


Cylinder Low 


Cylinder Low oe EE 


Cylinder High 


Device/Head 1 - 1 D - - - - Device/Head - ʻo ʻo o 
(Commana |1 1 1 O O 1 0 0 Status ... See Below... 


Error Register 


7 6 5 4 3 2 1 0 
CRCIUNC| 0 IDN | 0 | ABT | TON |AMN 


Table 97 Read Buffer Command (E4h) 


Cylinder High -s s s =s =- =- - 


Status Register 


7 6 5 4 3 2 1 0 
BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 
V vV 


The Read Buffer command transfers a sector of data from the sector buffer of device to the host. 
The sector is transferred through the Data Register 16 bits at a time. 


The sector transferred will be from the same part of the buffer written to by the last Write Buffer command. The 
contents of the sector may be different if any reads or writes have occurred since the Write Buffer command was 
issued. 
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11.15 Read DMA(C8h/C9h) 


re 
me fr 


Error Register Status Register 


7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 
CRC|JUNC| 0 IDN 0 | ABT | TON | AMN BSY | RDY | DF | DSC |DRQ | COR | IDX | ERR 


Table 98 Read DMA Command (C8h/C9h) 


The Read DMA command reads one or more sectors of data from disk media, then transfers the data from the 
device to the host. 


The sectors are transferred through the Data Register 16 bits at a time. 


The host initializes a slave-DMA channel prior to issuing the command. The data transfers are qualified by 
DMARQ and are performed by the slave-DMA channel. The device issues only one interrupt per command to 
indicate that data transfer has terminated and status is available. 


If an uncorrectable error occurs, the read will be terminated at the failing sector. 
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Output Parameters To The Device 


Sector Count The number of continuous sectors to be transferred. If zero is specified, then 256 
sectors will be transferred. 


Sector Number The sector number of the first sector to be transferred. (L=0) 
In LBA mode, this register specifies LBA address bits 0-7 to be transferred. (L=1) 
Cylinder High/Low The cylinder number of the first sector to be transferred. (L=0) 


In LBA mode, this register specifies LBA address bits 8-15 (Low) 16-23 (High) to be 
transferred. (L=1) 


H The head number of the first sector to be transferred. (L=0) 
In LBA mode, this register specifies LBA bits 24-27 to be transferred. (L=1) 


R The retry bit, but this bit is ignored. 

Input Parameters From The Device 

Sector Count The number of requested sectors not transferred. This will be zero, unless an 
unrecoverable error occurs. 

Sector Number The sector number of the last transferred sector. (L=0) 


In LBA mode, this register contains current LBA bits 0-7. (L=1) 
Cylinder High/Low The cylinder number of the last transferred sector. (L=0) 


In LBA mode, this register contains current LBA bits 8-15 (Low), 16-23 (High). (L=1) 


H The head number of the sector to be transferred. (L=0) 
In LBA mode, this register contains current LBA bits 24-27. (L=1) 
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11.16 Read DMA Ext (25h) 


Command Block Output Registers Command Block Input Registers 
e ICID 
e EEEE 


pata Hh ee baa High GERE 


Current -1-[-]|-]-| Error ...See Below... 
Feature 
Previous | - | - | - | - | -) 


Sector Count Sector Count 
sn | Previous verv 
Number — [previous |v [v |v |v [vv eae 


von Fem [v[v[v[v]v 
Cylinder Low Cylinder Low 
at Previous |v |v [v[v [vv 


vernon nee [v[v fev 
Cylinder High Cylinder T O 
Prevos || v[v[v[v[v HOB conor 
Device/Head eee DevceHead | Epp 
ems [oleae 


Error Register Status Register 


7 6 5 4 3 3 
CRC | UNC 0 IDN 0 ABT | TON EN KN RDY | DF Ei DRQ EA IDX BA 
PAR Pen 


Table 99 Read DMA Ext Command (25h) 


The Read DMA command reads one or more sectors of data from disk media, and then transfers the data from 
the device to the host. 


The sectors are transferred through the Data Register 16 bits at a time. 


The host initializes a slave-DMA channel prior to issuing the command. The data transfers are qualified by 
DMARQ and are performed by the slave-DMA channel. The device issues only one interrupt per command to 
indicate that data transfer has terminated and status is available. 


If an uncorrectable error occurs, the read will be terminated at the failing sector. 
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Output Parameters To The Device 


Sector Count Current The number of sectors to be transferred low order, bits (7:0). 

Sector Count Previous The number of sectors to be transferred high order, bits (15:8). If 0000h in the 
Sector Count register is specified, then 65,536 sectors will be transferred. 

Sector Number Current LBA (7:0) 

Sector Number Previous LBA (31:24) 

Cylinder Low Current LBA (15:8) 

Cylinder Low Previous LBA (39:32) 

Cylinder High Current LBA (23:16) 

Cylinder High Previous LBA (47:40) 


Input Parameters From The Device 
Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 


Sector Number (HOB=1) LBA (31:24)of the address of the first unrecoverable error. 


Cylinder Low (HOB=0) LBA (15:8)of the address of the first unrecoverable error. 

Cylinder Low (HOB=1) LBA (39:32)of the address of the first unrecoverable error. 
Cylinder High (HOB=0) LBA (23:16)of the address of the first unrecoverable error. 
Cylinder High (HOB=1) LBA (47:40)of the address of the first unrecoverable error. 


Hitachi hard disk drive specifications 
133 


11.17 Read FPDMA Queued (60h) 


Command Block Output Registers Command Block Input Registers 
e ICID 
e PE 


pata Hioh BEZAR baa High GERE 


Previous |v |v [Vv |v [v] 


Sector Count Sector Count 
seo ae foren | Previous | - | - | - | - | - | 

Sector Sector 
Number Number 


Cylinder Low Cylinder Low 
Previous [V |v |v [v [vv 


un. Tyv 
Cylinder High Cylinder T O 
Prevos |v |v |v [vvi HOB conor 
Device/Head eoan DevcerHead | -J-]-|-] 
ome fofefefefe 


Error Register Status Register 


5 3 


Table 100 Read FPDMA Queued Command (60h) 


The Read FPDMA command reads one or more sectors of data from disk media, and then transfers the data 
from the device to the host. 


If an uncorrectable error occurs, the read will be terminated at the failing sector. 
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Output Parameters To The Device 


Feature Current 

Feature Previous 

Sector Count Current 
TAG (bits 7-3) 


Sector Count Previous 
PRIO (bits 7) 


Sector Number Current 
Sector Number Previous 
Cylinder Low Current 
Cylinder Low Previous 
Cylinder High Current 
Cylinder High Previous 
Device/Head 

FUA (bit 7) 


The number of sectors to be transferred low order, bits (7:0). 
The number of sectors to be transferred high order, bits (15:8). 


The TAG value shall be assigned to be different from all other queued 
commands. The value shall not exceed the maximum queue depth specified by 
the Word 75 of the Identify Device information. 


The Priority (PRIO) value shall be assigned by the host based on the priority of 
the command issued. The device shall make a best effort to complete High 
priority requests in a more timely fashion than Normal priority requests. The 
Priority values are defined as follows: 
Ob Normal priority 
1b High priority 
LBA (7:0) 
LBA (31:24) 
LBA (15:8) 
LBA (39:32) 
LBA (23:16) 
LBA (47:40) 


When the FUA bit is set to 1, the requested data is always retrieved from the 
media regardless of whether the data are held in the sector buffer or not. 

When the FUA bit is set to 0, the data may be retrieved from the media or from 
the cached data left by previously processed Read or Write commands. 


Input Parameters From The Device 


Sector Number (HOB=0) 
Sector Number (HOB=1) 
Cylinder Low (HOB=0) 
Cylinder Low (HOB=1) 
Cylinder High (HOB=0) 
Cylinder High (HOB=1) 


LBA (7:0) of the address of the first unrecoverable error. 
LBA (31:24)of the address of the first unrecoverable error. 
LBA (15:8)of the address of the first unrecoverable error. 
LBA (39:32)of the address of the first unrecoverable error. 
LBA (23:16)of the address of the first unrecoverable error. 


LBA (47:40)of the address of the first unrecoverable error. 
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11.18 Read Log Ext (2Fh) 


Command Block Output Registers 
reise peee 
pene 


[Data High o [Data High o 
w 
Feature 
CS A A a a [ 
em fii 
Sector Count 
emne [vo [v i 
ren Fibi 
Sector Number 
fork ae ie ela! 
er [vel oye [ve 
Cylinder Low 
rev [yy yo [ve [e 
jourent_ || -|-[-]-[-[- || 


Cylinder High 

ke 
Dace APE EEE 
comme PEER ENE 


Error oe 


Command Block Input Registers 

Rose Peppe 
Baio e 
paatin PPT! 


Error ...See Below... 


Hos-o|-|-[-|-|-[-|-|-| 
Sector Count 

søt] 

nos=0|-|-|-|-[-|-|-|- 
Sector Number 
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ag e eea 
Cylinder Low 

e ee ee 
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Cylinder High 
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Status — 
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Table 101 Read Log Ext Command (2Fh) 


This command returns the specified log to the host. The device shall interrupt for each DRQ block transferred. 
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Output Parameters To The Device 
Feature Log Address Specific 


Sector Count Current The number of sectors to be read from the specified log low order, bits (7:0). 
The log transferred by the drive shall start at the sector in the specified log at the 
specified offset, regardless of the sector count requested. 


Sector Count Previous The number of sectors to be read from the specified log high orders, bits (15:8). 
Sector Number Current The log to be returned as described in 0. 


Cylinder Low Current The first sector of the log to be read low order, bits (7:0). 


Cylinder Low Previous The first sector of the log to be read high order, bits (15:8). 


00h Log directory N/A Read Only 
03h Extended Comprehensive SMART error log SMART error logging Read Only 
06h SMART self-test log SMART self-test See Note 
07h Extended SMART self-test log SMART self-test Read Only 
08h Power Conditions log Extended Power Condition Read Only 
10h Command Error Native Command Queuing Read Only 
11h Phy Event Counters Serial ATA Read Only 
20h Streaming Performance log Streaming Read Only 
21h Write Stream Error log Streaming Read Only 
22h Read Stream Error log Streaming Read Only 
80h-9Fh Host vendor specific SMART Read/Write 
Note: If log address 06h is accessed using the Read Log Ext or Write Log Ext commands, command abort shall be 
returned. 


Note: Please see 9.17.3 about Phy Event Counter. 
Table 102 Log Address Definition 


The Extended SMART self-test log sector shall support 48-bit and 28-bit addressing. All 28-bit entries contained 
in the SMART self-test log sector shall also be included in the Comprehensive SMART self-test log sector with 
the 48-bit entries. 


If the feature set associated with the log specified in the Sector Number register is not supported or enabled, or if 
the values in the Sector Count, Sector Number or Cylinder Low registers are invalid, the device shall return 
command aborted. 
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11.18.1 General Purpose Log Directory 
Table 103 defines the 512 bytes that make up the General Purpose Log Directory. 


Table 103 General Purpose Log Directory 


The value of the General Purpose Logging Version word shall be 0001h. A value of 0000h indicates that there is 
no General Purpose Log Directory. 


The logs at log addresses 80-9Fh shall each be defined as 16 sectors long. 
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11.18.2 Extended Comprehensive SMART Error log 


Table 104 defines the format of each of the sectors that comprise the Extended Comprehensive SMART error 
log. Error log data structure shall not include errors attributed to the receipt of faulty commands such as 
command codes not implemented by the device or requests with invalid parameters or in valid addresses. 


eon 1 yes |e 


Reset Pa 


ee I 


Table 104 Extended Comprehensive SMART Error Log 


11.18.2.1 Error log version 
The value of this version shall be O1h. 
11.18.2.2 Error log index 


This indicates the error log data structure representing the most recent error. If there have been no error log 
entries, it is cleared to 0. Valid values for the error log index are 0 to 4. 
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11.18.2.3 Extended Error log data structure 


An error log data structure shall be presented for each of the last four errors reported by the device. 

These error log data structure entries are viewed as a circular buffer. The fifth error shall create an error log 
structure that replaces the first error log data structure. The next error after that shall create an error log data 
structure that replaces the second error log structure, etc. 

Unused error log data structures shall be filled with zeros. 


Data format of each error log structure is shown below. 


Table 105 Extended Error log data structure 


Command data structure: Data format of each command data structure is shown below. 


18 


Note: bits (7:0) refer to the most recently written contents of the register. Bits (15:8) refer to the 
contents of the register prior to the most recent write to the register. 


Table 106 Command data structure 
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Error data structure: Data format of error data structure is shown below. 


Offset 
00h 
O1h 
02h 
03h 
04h 
O5h 
O6h 
07h 
08h 
09h 
OAh 
OBh 
OCh 
1Fh 
20h 


Note: bits (7:0) refer to the contents if the register is read with bit 7 of the Device Control 
register cleared to zero. Bits (15:8) refer to the contents if the register is read with bit 7 of the 
Device Control register set to one. 


Table 107 Error data structure 


State shall contain a value indicating the state of the device when the command was issued to the device or the 
reset occurred as described below. 


Value State 

x0h Unknown 

xih Sleep 

x2h Standby 

x3h Active/ldle 

x4h SMART Off-line or Self-test 
x5h-xAh Reserved 

XBh-xFh Vendor specific 


Note: The value of x is vendor specific. 
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11.18.2.4 Device error count 


This field shall contain the total number of errors attributable to the device that have been reported by the device 
during the life of the device. This count shall not include errors attributed to the receipt of faulty commands such 
as commands codes not implemented by the device or requests with invalid parameters or invalid addresses. If 
the maximum value for this field is reached the count shall remain at the maximum value when additional errors 
are encountered and logged. 


11.18.38 Extended Self-test log sector 


Table 108 defines the format of each of the sectors that comprise the Extended SMART self-test log. 


The Extended SMART self-test log sector shall support 48-bit and 28-bit addressing. All 28-bit entries contained 
in the SMART self-test log, defined in 7.42.6, “Self-test log data structure" on page 216 shall also be included in 
the Extended SMART self-test log with all 48-bit entries. 


C Bs [ors 
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Table 108 Extended Self-test log data structure 


These descriptor entries are viewed as a circular buffer. The nineteenth self-test shall create a descriptor entry 
that replaces descriptor entry 1. The next self-test after that shall create a descriptor entry that replaces 
descriptor entry 2, etc. All unused self-test descriptors shall be filled with zeros. 


11.18.3.1 Self-test log data structure revision number 
The value of this revision number shall be O1h. 
11.18.3.2 Self-test descriptor index 


This indicates the most recent self-test descriptor. If there have been no self-tests, this is set to zero. Valid 
values for the Self-test descriptor index are 0 to 18. 
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11.18.3.3 Extended Self-test log descriptor entry 
The content of the self-test descriptor entry is shown below. 
Description | Bytes | Offset | 
Self-test number 
Self-test execution status 
Power-on life timestamp in hours 
Self-test failure check point 


Failing LBA (7:0) 


Failing LBA (23:16) 


Failing LBA (31:24) 
Failing LBA (39:32) 
Failing LBA (47:40) 


Vendor specific 


Failing LBA (15:8) 


e 


a 


Table 109 Extended Self-test log descriptor entry 


11.18.4 Power Conditions log 


defines the Power Conditions log . If the Extended Power Conditions feature set is not supported, then the 
Power Conditions log shall not be supported. 


Each Power is composed of the following formats. 

Power Conditions log composes in order of Idle a, Idle b, Idle c and Standby y, Standby z.. 
Offset | Type Description 
0..1 Word Power Condition Flags 

Bit Description 

15 Power Condition Supported Power condition supported shall be set to one to 

indicate that power condition is support. 

14 Timer Saveable 

1= Idle a timer is saveable 

O= Idle a timer is not saveable 

13 Timer Changeable 

1= Idle a timer is changeable 

0= Idle a timer is not changeable 

12 Default Timer Enabled 

1= Default Idle a timer is enabled 

O= Default Idle a timer is disabled 

11 Saved Timer Enabled 

1= Saved Idle a timer is enabled 

O= Saved Idle a timer is disabled 

10 Current Timer Enabled 

1= Current Idle_a timer is enabled 

O= Current Idle_a timer is disabled 

9:0 Reserved 
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Offset | Type Description 

2..3 Word Reserved 

4..7 DWrod | Default Timer setting 
The Default Timer setting is the minimum time that the device shall wait after 
command completion before entering the power condition of the power 
management state. A value of zero indicates that this power condition is 
disabled . A value of FFFF_FFFFh indicates that the time is greater than or equal 
to 429 496 729 500 milliseconds. 
Measurement Units: 100 milliseconds. 

8..11 DWord | Saved Timer setting 
The Saved Timer setting is the minimum time that the device shall wait after 
command completion before entering the power condition of the power 
management state . A value of zero indicates that this power condition is 
disabled . A value of FFFF_FFFFh indicates that the time is greater than or equal 
to 429 496 729 500 milliseconds. 
Measurement Units: 100 milliseconds. 

12..15 | DWord | Current Timer setting 
The Current Timer setting is the minimum time that the device shall wait after 
command completion before entering the power condition of the power 
management state . A value of zero indicates that this power condition is 
disabled . A value of FFFF_FFFFh indicates that the time is greater than or equal 
to 429 496 729 500 milliseconds. 
Measurement Units: 100 milliseconds 

16..19 | DWord | Nominal Recovery time from to PMO:Active power management state 
The Nominal Recovery time from power to PMO: Active is the nominal time 
required to transition from power to PMO:Active power management state. This 
time does not include processing time for the command that caused this 
transition to occur . A value of zero indicates that the nominal recovery time is not 
specified . A value of FFFF_FFFFh indicates that the recovery time is greater 
than or equal to 429 496 729 500 milliseconds. 
Measurement Units: 100 milliseconds. 
This value shall be preserved over all resets. 

20..23 | DWord | Minimum timer setting 
The Minimum timer setting is the minimum timer value allowed by the Set Power 
Condition Timer subcommand for the timer . A value of zero indicates that the 
minimum timer value is not specified . A value of FFFF_FFFFh indicates that the 
minimum timer value is greater than or equal to 429 496 729 500 milliseconds. 
Measurement Units: 100 milliseconds 
This value shall be preserved over all resets 

24..27 | DWord | Maximum timer setting 
The Maximum timer setting is the maximum timer value allowed by the Set Power 
Condition Timer subcommand for the timer . A value of zero indicates that the 
maximum timer value is not specified . A value of FFFF FFFFh indicates that the 
maximum timer value is greater than or equal to 429 496 729 500 milliseconds. 
Measurement Units: 100 milliseconds 
This value shall be preserved over all resets 

28..31 | DWord | Reserved 
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11.18.5 Command Error 


Table 110 defines the format of the Command Error data structure. 


faa he) as oe a eo 
10 
11 
12 
13 
14 - 255 
256 — 510 
511 


Table 110 Command Error information 


The TAG field (Byte 0 Bits 4-0) contains the tag number corresponding to a queued command if the NQ bit is 
cleared. 

The NQ field (Byte 0 Bit 7) indicates whether the error condition was a result of a non-queued or not. If it is 
cleared the error information corresponds to a queued command specified by the tag number indicated in the 
TAG field. 

The bytes 1 to 13 correspond to the contents of Shadow Register Block when the error was reported. 

The Data Structure Checksum (Byte 511) contains the 2’s complement of the sum of the first 511 bytes in the 
data structure. The sum of all 512 bytes of the data structure will be zero when the checksum is correct. 
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11.18.6 Read Stream Error log 


Table 111 defines the format of the Read Stream Error log. Entries are placed into the Read Stream Error log 
only when the SE bit is set to one in the Status Register. The 512 bytes returned shall contain a maximum of 
31 error entries. The Read Stream Error Count shall contain the total number of Read Stream Errors detected 
since the last successful completion of the Read Log Ext command with LBA Low register set to 22h. This 
error count may be greater than 31, but only the most recent 31 errors are represented by entries in the log. If 
the Read Stream Error Count reaches the maximum value that can be represented after the next error is 
detected the Read Stream Error Count shall remain at the maximum value. After successful completion of a 
Read Log Ext command with the LBA Low Register set to 22h, the Read Stream Error Log shall be reset to a 
power-on or hardware reset condition, with the Error Log Index and Read Stream Error Count cleared to zero. 
The Read Stream Error Log is not preserved across power cycles and hardware reset. 


Table 111 Read Stream Error Log 


The Data Structure Version field shall contain a value of 02h indicating the second revision of the structure 
format. 


The Read Stream Error Log Count field shall contain the number of uncorrected sector entries currently 
reportable to the host. This value may exceed 31. 


The Error Log Index indicates the error log data structure representing the most recent error. Only values 
(31:1) are valid. 


Table 111 defines the format of each entry in the Read Stream Error Log. 
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Description 

Feature Register Contents Value (current) 
Feature Register Contents Value (previous) 
Status Register Contents Value 

Error Register Contents Value 

LBA (7:0) 

LBA (15:8) 

LBA (23:16) 

LBA (31:24) 

LBA (39:32) 

LBA (47:40) 


Reserved 


Sector Count (LSB) 
Sector Count (MSB) 


Reserved 


Table 112 Stream Error Log entry 


Byte (1:0) contains the contents of the Feature Register when the error occurred. This Value shall be set to 
OFFFFh for s deferred write error. 


Byte 2 contains the contents of the Status Register when the error occurred. 
Byte 3 contains the contents of the Error Register when the error occurred. 
Byte (9:4) indicates the starting LBA of the error. 


Byte (13:12) indicate the length of the error. Therefore, each entry may describe a range of sectors at the 
given address and spanning the specified number of sectors. 
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11.18.7 Write Stream Error log 


Table 113 defines the format of the Write Stream Error log. Entries are placed into the Write Stream Error log 
only when the SE bit is set to one in the Status Register. The 512 bytes returned shall contain a maximum of 
31 error entries. The Write Stream Error Count shall contain the total number of Write Stream Errors detected 
since the last successful completion of the Read Log Ext command with LBA Low register set to 21h. This error 
count may be greater than 31, but only the most 31 errors are represented by entries in the log. If the Write 
Stream Error Count reaches the maximum value that can be represented after the next error is detected the 
Write Stream Error Count shall remain at the maximum value. After successful completion of a Read Log Ext 
command with the LBA Low Register set to 21h, the Write Stream Error Log shall be reset to a power-on or 
hardware reset condition, with the Error Log Index and Write Stream Error Count cleared to zero. The Write 
Stream Error Log is not reserved across power cycles and hardware reset. 


Table 113 Write Stream Error Log 


The Data Structure Version field shall contain a value of 02h indicating the second revision of the structure 
format. 


The Write Stream Error Log Count field shall contain the number of Write Stream command entries since the last 
power on, since this log was last read, or since hardware reset was executed. 


The Error Log Index indicates the error log data structure representing the most recent error. Only values 
(31:0) are valid. 


Table 111 defines the format of each entry in the Error Log. 
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11.18.8 Streaming Performance log 


Table 114 defines the format of the log returned by the Read Log Ext command, when the LBA Low register is 
20h. This data set is referred to as the Streaming Performance Parameters log, the length of which (in sectors) 
is statically indicated in Read Log Ext log address 00h (Log Directory). 


The host should base its calculations on the larger of its Typical Host Interface Sector Time and the device 
reported Sector Time values, and on the sum of the device reported Access Time values and any additional 
latency that only the host is aware of (e.g. host command overhead, etc.). 


Description Bytes 


(n+6)-(n+7) 


Time that may be required to begin access at new stream access position, in (n+2)-(n+3) 
(Identify Device words (99:98))/256 time units 


Table 117 Access Time Array Entry (Linearly Interpolated) 
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11.19 Read Multiple (C4h) 


| 


Command Block Input Registers 
7 6 5 4 3 2 1 0 


Cylinder High VV VV VV VV 
Device/Head 1 L 1 D H H H H 


VVVVVV Vv 
s - - + HH HH 


Error Register 
4 3 2 1 (0) 


7 6 5 
CRC|UNC| 0 IDN 0 | ABT | TON | AMN 
EE) 


Table 118 Read Multiple Command (C4h) 


7 6 5 4 3 2 1 
BSY | RDY | DF | DSC | DRQ | COR 


ALARA 


<|3 e| 


The Read Multiple command reads one or more sectors of data from disk media, and then transfers the data 
from the device to the host. 


The sectors are transferred through the Data Register 16 bits at a time. Command execution is identical to the 
Read Sector(s) command except that an interrupt is generated for each block (as defined by the Set Multiple 
command) instead of for each sector. 
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11.20 Read Multiple Ext (29h) 


Command Block Output Registers 
er Prepp) 
pem FLL 


Data High 


Feature 
Previous | - | - | - | - | - | 


Sector Count 
V 
| 
Cylinder Low 
on om be Lee Y 
Cylinder High 
v 


Command Block Input Registers 
SPR] 
eam Je 


mm EE EEE 


HOB=0 
Sector Count 

HOB=1 
Sector HOB=0 
Number HOB=1 


| HOB=0 
Cylinder Low 
HOB=1 


HOB=0 


Status Register 


7 6 5 4 3 2 1 0 


ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


Table 119 Read Multiple Ext Command (29h) 


The Read Multiple Ext command reads one or more sectors of data from disk media, and then transfers the data 
from the device to the host. 


The sectors are transferred through the Data Register 16 bits at a time. Command execution is identical to the 
Read Sector(s) command except that an interrupt is generated for each block (as defined by the Set Multiple 
command) instead of for each sector. 
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Output Parameters To The Device 


Sector Count Current The number of continuous sectors to be transferred low order, bits (7:0). 

Sector Count Previous The number of continuous sectors to be transferred high order, bits (15:8). If 
0000h is specified in the Sector Count register, then 65,536 sectors will be 
transferred. 


Sector Number Current LBA (7:0). 
Sector Number Previous LBA (31:24). 


Cylinder Low Current LBA (15:8). 
Cylinder Low Previous LBA (39:32). 
Cylinder High Current LBA (23:16). 


Cylinder High Previous LBA (47:40). 

Input Parameters From The Device 

Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 
Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 
Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 
Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 
Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 
Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 
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11.21 Read Native Max Address (F8h) 


Block Output Registers Command Command Block Input Registers 
6 5 4 


Register 


Sector Number |V V V V V V V V 


Cylinder Low HET Cylinder Low vvvvvvvv] VV VV V VV 


Cylinder High Cylinder High VV VV VV VV 


Device/Head 1 L 1 D - - - - Device/Head - - - H H H H 


Error Register Status Register 


Table 120 Read Native Max ADDRESS (F8h) 


This command returns the native max LBA/CYL of HDD which is not affected by Set Max Address command. 


The 48-bit native max address is greater than 268,435,455; the Read Native Max Address command shall return 
a value of 268,435,455. 


Input Parameters From The Device 
Sector Number In LBA mode, this register contains native max LBA bits 0-7. (L=1) 
In CHS mode, this register contains native max sector number. (L=0) 
Cylinder High/Low In LBA mode, this register contains native max LBA bits 8-15 (Low), 16-23 (High). 
(L=1) 
In CHS mode, this register contains native max cylinder number. (L=0) 
H In LBA mode, this register contains native max LBA bits 24-27. (L=1) 
In CHS mode, this register contains native max head number.(L=0) 
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11.22 Read Native Max Address Ext (27h) 


Command Block Output Registers Command Block Input Registers 
easter Pppp freser — [refs 
aaron e parow Ef fe ff] 
Data High f-t] [Daa rion Bo aloe eee eel 
ren [ER 
Feature 
ep do 
ee eer ae ERA 
Sector Count Sector Count 


previous | -[-]-[-|-[-|-|- ekke 

feurent |-|-f--|-|-|-|-] HOB=0 
Sector Number Sector Number 

Previous |-|-]-|-[-]-]-|-| HOB=1 

jourent |-[-|-|-|-|-|-|- HOB-0 
Cylinder Low Cylinder Low 

Previous |-|-[-]-[-|-|-|-] HOB=1 

feurent |-|-f-]-|-|-|-|-] HOB=0 
Cylinder High Cylinder High 

eves ELLE HoB=1 
Device/Head Device/Head -J-e 
E 


Error Register 


Status Register 


5 
KEENE EEE EFE EE EA 


Table 121 Read Native Max Address Ext (27h) 


This command returns the native max LBA of HDD which is not effected by Set Max Address Ext command. 


Input Parameters From The Device 

Sector Number (HOB=0) LBA (7:0) of the address of the Native max address. 
Sector Number (HOB=1) LBA (31:24) of the address of the Native max address. 
Cylinder Low (HOB=0) LBA (15:8) of the address of the Native max address. 
Cylinder Low (HOB=1) LBA (39:32) of the address of the Native max address. 
Cylinder High (HOB=0) LBA (23:16) of the address of the Native max address. 
Cylinder High (HOB=1) LBA (47:40) of the address of the Native max address. 
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11.23 Read Sector(s) (20h/21h) 


nm | 


Command Block Input Registers 


7 6 5 4 3 2 1 0 
VV VV VV VV 
VV VV VV VV 
VV VV VV VV 


Cylinder High VV VV VV V V 
Device/Head 1 L 1 D H H H H 


VV VV VV VV 
- - - - H HH UH 


Error Register 


7 6 5 4 3 2 1 0 
CRC|]UNC] 0 IDN 0 | ABT | TON | AMN 
FIFIEN ENE 


Table 122 Read Sector(s) Command (20h/21h) 


7 6 5 4 3 2 
BSY | RDY | DF | DSC |DRQ|COR 


HØNE 


The Read Sector(s) command reads one or more sectors of data from disk media, and then transfers the data 
from the device to the host. 


The sectors are transferred through the Data Register 16 bits at a time. 


If an uncorrectable error occurs, the read will be terminated at the failing sector. 
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Output Parameters To The Device 


Sector Count The number of continuous sectors to be transferred. If zero is specified, then 256 
sectors will be transferred. 


Sector Number The sector number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 0 — 7. (L=1) 
Cylinder High/Low The cylinder number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 8 — 15 (Low), 16 — 23 (High). (L=1) 
H The head number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 24 — 27. (L=1) 
R The retry bit, but this bit is ignored. 
Input Parameters From The Device 
Sector Count The number of requested sectors not transferred. This will be zero, unless an 
unrecoverable error occurs. 
Sector Number The sector number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 0 — 7. (L=1) 
Cylinder High/Low The cylinder number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 8 — 15 (Low), 16 — 23 (High). 
(L=1) 
H The head number of the last transferred sector. (L=0) 


In LBA mode, this register contains current LBA bits 24 — 27. (L=1) 
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11.24 Read Sector(s) Ext (24h) 


Command Block Output Registers Command Block Input Registers 
easter Pppp 
baarn LHL 


Data High EEE 
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Feature 
Previous | - | - | - | - | - fe sl 
Sector Count Sector Count 


Number v Number HOB=1 


700 
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... See Below... 
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Error Register Status Register 


7 6 5 4 3 7 6 5 4 3 2 1 0 
CRC | UNC 0 IDN 0 BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 
V 


V 


Device/Head 


Table 123 Read Sector(s) Ext Command (24h) 


The Read Sector(s) Ext command reads from 1 to 65,536 sectors of data from disk media, and then transfers 
the data from the device to the host. 


The sectors are transferred through the Data Register 16 bits at a time. 


If an uncorrectable error occurs, the read will be terminated at the failing sector. 
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Output Parameters To The Device 


Sector Count Current The number of continuous sectors to be transferred low order, bits (7:0) 

Sector Count Previous The number of continuous sectors to be transferred high order, bits (15:8). If 
zero is specified in the Sector Count register, then 65,536 sectors will be 
transferred. 


Sector Number Current LBA (7:0). 
Sector Number Previous LBA (31:24). 


Cylinder Low Current LBA (15:8). 
Cylinder Low Previous LBA (39:32). 
Cylinder High Current LBA (23:16). 


Cylinder High Previous LBA (47:40). 

Input Parameters From The Device 

Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 
Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 


Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 

Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 
Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 
Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 
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11.25 Read Stream DMA (2Ah) 


Command Block Output Registers Command Block Input Registers 
eger — [rep] 
Daarn LETT Daarn EN EN EN ER EN 
Data High ear ECEE 


PIES pes ES fe 
ee [Pee 
dii E 


Pes [v |v [v [vv 

einen [v[v[v[v[v[ 
Sector Count 

[revo [vv |v [v [vv 
sean [owen [vv [vv [vv 
wwr [ewe [vv [vv [| 

uren [www [vv 
Cylinder Low 

revo [vv |v [v [vv 

einen [v[v[v[v[v[ 
Cylinder High 

[revo [vv |v [v [vv 
Device/Head EBEA 
commana — —fofofifofa) 
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Table 124 Read Stream DMA Command (2Ah) 


The Read Stream DMA command reads one to 65536 sectors as specified in the Sector Count register. A 
value of 0000h in the Sector Count register requests 65536 sectors. 


The RC bit indicates that the drive operate in a continuous read mode for the Read Stream command. When RC 
is cleared to zero the drive shall operate in normal Streaming read mode. 


When the Read Continuous mode is enabled, the device shall transfer data of the requested length without 
setting the ERR bit to one. The SE bit shall be set to one if the data transferred includes errors. The data may 
be erroneous in this case. 


If the Read Continuous bit is set to one, the device shall not stop execution of the command due to errors. If 
the RC bit is set to one and errors occur in reading or transfer of the data, the device shall continue to transfer 
the amount of data requested and then provide ending status with the BSY bit cleared to zero, the SE bit set to 
one, the ERR bit cleared to zero, and the type of error, ICRC,UNC,IDNF or ABRT, reported in the error log. If 
the RC bit is set to one and the Command Completion Time Limit expires, the device shall stop execution of the 
command and provide ending status with BSY bit cleared to zero, the SE bit set to one, the ERR bit cleared to 
zero, and report the fact that the Command Completion Time Limit expired by setting the CCTO bit in the error 
log to one, In all cases, the device shall attempt to transfer the amount of data requested within the Command 
Completion Time Limit event if some data transferred is in error. 
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Output Parameters To The Device 


Feature Current 
URG (bit7) 


RC (bit6) 


NS (bit5) 


HSE (bit4) 


Stream ID (bit 0..2) 


Feature Previous 
CCTL (7:0) 


Sector Count Current 
Sector Count Previous 


Sector Number Current 
Sector Number Previous 
Cylinder Low Current 
Cylinder Low Previous 
Cylinder High Current 
Cylinder High Previous 


URG specifies an urgent transfer request. The Urgent bit specifies that the 
command should be completed in the minimum possible time by the device and 
shall be completed within the specified Command Completion Time Limit. 


RC specifies Read Continuous mode enabled. If the Read Continuous bit is set 
to one, the device shall not stop execution of the command due to errors. 

If the RC bit is set to one and errors occur in reading or transfer of the data, the 
device shall continue to transfer the amount of data requested and then provide 
ending status with BSY bit cleared to zero, the SE bit set to one, the ERR bit 
cleared to zero, and the type of error, ICRC, UNC, IDNF or ABRT reported in the 
error log. 

If the RC bit is set to one and the CCTL expires, the device shall stop execution 
of the command and provide ending status with the BSY bit cleared to zero, the 
SE bit set to one, the ERR bit cleared to zero, and report the fact that the CCTL 
expired by setting the CCTO bit in the error log to one. 

In all cases, the device shall attempt to transfer the amount of data requested 
within the CCTL even if some data transferred is in error. 


NS (Not Sequential) may be set to one if the next read stream command with the 
same Stream ID may not be sequential in LBA space. 


HSE (Handle Stream Error) specifies that this command starts at the LBA of the 

last reported error for this stream, so the device may attempt to continue its 

corresponding error recovery sequence where it left off earlier. 

Stream ID specifies the stream to be read. The device shall operate according 

to the Stream ID set by the Read Stream command. 

The time allowed for the current command’s completion is calculated as follows: 
Command Completion Time Limit = (content of the Feature register 

Previous) * (Identify Device words (99:98)) useconds 

If the value is zero, the device shall use the Default CCTL supplied with a 

previous Configure Stream command for this Stream ID. If the Default CCTL 

is zero, or no previous Configure Stream command was defined for this Stream 

ID, the drive will ignore the CCTL. The time is measured from the write of the 

command register to the final INTRQ for command completion. The device has 

minimum CCTL value. When the specified value is shorter than the minimum 

value, CCTL is set to the minimum value. Actual minimum CCTL value is 

described in the “Deviations from Standard” section. 

The number of continuous sectors to be transferred low order, bits (7:0) 


The number of continuous sectors to be transferred high order, bits (15:8). If 
zero is specified in the Sector Count register, then 65,536 sectors will be 
transferred. 


LBA (7:0). 
LBA (31:24). 
LBA (15:8). 
LBA (39:32). 
LBA (23:16). 
LBA (47:40). 


Input Parameters From The Device 


Sector Number (HOB=0) 
Sector Number (HOB=1) 


LBA (7:0) of the address of the first unrecoverable error. 
LBA (31:24) of the address of the first unrecoverable error. 
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Cylinder Low (HOB=0) 
Cylinder Low (HOB=1) 
Cylinder High (HOB=0) 
Cylinder High (HOB=1) 
CCTO (Error, bit 0) 


SE (Status, bit 5) 


LBA (15:8) of the address of the first unrecoverable error. 

LBA (39:32) of the address of the first unrecoverable error. 
LBA (23:16) of the address of the first unrecoverable error. 
LBA (47:40) of the address of the first unrecoverable error. 


CCTO bit shall be set to one if a Command Completion Time Limit Out error has 
occurred. 

SE (Stream Error) shall be set to one if an error has occurred during the 
execution of the command and the RC bit is set to one, In this case the LBA 
returned in the Sector Number registers shall be the address of the first sector in 
error, and the Sector Count registers shall contain the number of consecutive 
sectors that may contain errors. If the RC bit is set to one when the command 
is issued and ICRC, UNC, IDNF, ABRT, or CCTO error occurs, the SE bit shall 
be set to one, the ERR bit shall be cleared to zero, and the bits that would 
normally be set in the Error register shall be set in the error log. 
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11.26 Read Stream PIO (2Bh) 


Command Block Output Registers Command Block Input Registers 
reaver eE 
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[Data High | [Data High | 
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Error Register Status Register 


Table 125 Read Stream PIO Command (2Bh) 


The Read Stream DMA command reads one to 65536 sectors as specified in the Sector Count register. A 
value of 0000h in the Sector Count register requests 65536 sectors. 


The RC bit indicates that the drive operate in a continuous read mode for the Read Stream command. When RC 
is cleared to zero the drive shall operate in normal Streaming read mode. 


When the Read Continuous mode is enabled, the device shall transfer data of the requested length without 
setting the ERR bit. The SE bit shall be set to one if the data transferred includes errors. The data may be 
erroneous in this case. 


If the Read Continuous bit is set to one, the device shall not stop execution of the command due to errors. If 
the RC bit is set to one and errors occur in reading or transfer of the data, the device shall continue to transfer 
the amount of data requested and then provide ending status with the BSY bit cleared to zero, the SE bit set to 
one, the ERR bit cleared to zero, and the type of error, ICRC,UNC,IDNF, or ABRT, reported in the error log. If 
the RC bit is set to one and the Command Completion Time Limit expires, the device shall stop execution of the 
command and provide ending status with BSY bit cleared to zero, the SE bit set to one, the ERR bit cleared to 
zero, and report the fact that the Command Completion Time Limit expired by setting the CCTO bit in the error 
log to one, In all cases, the device shall attempt to transfer the amount of data requested within the Command 
Completion Time Limit event if some data transferred is in error. 
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Output Parameters To The Device 


Feature Current 
URG (bit7) 


RC (bit6) 


NS (bit5) 


HSE (bit4) 


Stream ID (bit 0..2) 


Feature Previous 
CCTL (7:0) 


Sector Count Current 
Sector Count Previous 


Sector Number Current 
Sector Number Previous 
Cylinder Low Current 
Cylinder Low Previous 
Cylinder High Current 
Cylinder High Previous 


URG specifies an urgent transfer request. The Urgent bit specifies that the 
command should be completed in the minimum possible time by the device and 
shall be completed within the specified Command Completion Time Limit. 


RC specifies Read Continuous mode enabled. If the Read Continuous bit is set 
to one, the device shall not stop execution of the command due to errors. 

If the RC bit is set to one and errors occur in reading or transfer of the data, the 
device shall continue to transfer the amount of data requested and then provide 
ending status with BSY bit cleared to zero, the SE bit set to one, the ERR bit 
cleared to zero, and the type of error, UNC, IDNF or ABRT reported in the error 
log. 

If the RC bit is set to one and the CCTL expires, the device shall stop execution of 
the command and provide ending status with the BSY bit cleared to zero, the SE 
bit set to one, the ERR bit cleared to zero, and report the fact that the CCTL 
expired by setting the CCTO bit in the error log to one. 

In all cases, the device shall attempt to transfer the amount of data requested 
within the CCTL even if some data transferred is in error. 


NS (Not Sequential) may be set to one if the next read stream command with the 
same Stream ID may not be sequential in LBA space. 


HSE (Handle Stream Error) specifies that this command starts at the LBA of the 
last reported error for this stream, so the device may attempt to continue its 
corresponding error recovery sequence where it left off earlier. 


Stream ID specifies the stream to be read. The device shall operate according to 
the Stream ID set by the Read Stream command. 


The time allowed for the current command’s completion is calculated as follows: 
Command Completion Time Limit = (content of the Feature register 

Previous) * (Identify Device words (99:98)) microseconds 

If the value is zero, the device shall use the Default CCTL supplied with a previous 

Configure Stream command for this Stream ID. If the Default CCTL is zero, or no 

previous Configure Stream command was defined for this Stream ID, the device 

will ignore the CCTL. The time is measured from the write of the command 

register to command completion. The device has minimum CCTL value. When the 

specified value is shorter than the minimum value, CCTL is set to the minimum 

value. Actual minimum CCTL value is described in the “Deviations from Standard” 

section. 

The number of continuous sectors to be transferred low order, bits (7:0) 

The number of continuous sectors to be transferred high order, bits (15:8). If zero 

is specified in the Sector Count register, then 65,536 sectors will be transferred. 

LBA (7:0). 

LBA (31:24). 

LBA (15:8). 

LBA (39:32). 

LBA (23:16). 

LBA (47:40). 


Input Parameters From The Device 


Sector Number (HOB=0) 
Sector Number (HOB=1) 


LBA (7:0) of the address of the first unrecoverable error. 
LBA (31:24) of the address of the first unrecoverable error. 
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Cylinder Low (HOB=0) 
Cylinder Low (HOB=1) 
Cylinder High (HOB=0) 
Cylinder High (HOB=1) 
CCTO (Error, bit 0) 


SE (Status, bit 5) 


LBA (15:8) of the address of the first unrecoverable error. 

LBA (39:32) of the address of the first unrecoverable error. 

LBA (23:16) of the address of the first unrecoverable error. 

LBA (47:40) of the address of the first unrecoverable error. 

CCTO bit shall be set to one if a Command Completion Time Limit Out error has 
occurred. 


SE (Stream Error) shall be set to one if an error has occurred during the execution 
of the command and the RC bit is set to one. In this case the LBA returned in the 
Sector Number registers shall be the address of the first sector in error, and the 
Sector Count registers shall contain the number of consecutive sectors that may 
contain errors. If the RC bit is set to one when the command is issued and a 
UNC, IDNF, ABRT, or CCTO error occurs, the SE bit shall be set to one, the ERR 
bit shall be cleared to zero, and the bits that would normally be set in the Error 
register shall be set in the error log. 
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11.27 Read Verify Sector(s) (40h/41h) 


Command Block Output Registers Command Block Input Registers 
oaa fr] 


rn [ee 


Cylinder Low VV VV VV VV Cylinder Low Vv VV VV VV 


Cylinder High VV VV VV V V Cylinder High Vv VV VV VV 
Device/Head 1 L 1 D H H H H Device/Head - - - - H H H H 


Error Register Status Register 
7 6 5 4 3 2 1 0 


7 6 5 4 3 2 1 0 
CRC|JUNC| 0 IDN 0 | ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 
V V 


NNN 


Table 126 Read Verify Sector(s) Command (40h/41h) 


The Read Verify Sector(s) verifies one or more sectors on the device. No data is transferred to the host. 


The difference between Read Sector(s) command and Read Verify Sector(s) command is whether the data is 
transferred to the host or not. 


If an uncorrectable error occurs, the read verify will be terminated at the failing sector. 
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Output Parameters To The Device 


Sector Count The number of continuous sectors to be verified. If zero is specified, then 256 
sectors will be verified. 

Sector Number The sector number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 0 — 7. (L=1) 

Cylinder High/Low The cylinder number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 8 — 15 (Low), 16 — 23 (High). (L=1) 

H The head number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 24 — 27. (L=1) 

R The retry bit, but this bit is ignored. 

Input Parameters From The Device 

Sector Count The number of requested sectors not verified. This will be zero, unless an 
unrecoverable error occurs. 

Sector Number The sector number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 0 — 7. (L=1) 

Cylinder High/Low The cylinder number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 8 — 15 (Low), 16 — 23 (High). 
(L=1) 

H The head number of the last transferred sector. (L=0) 


In LBA mode, this register contains current LBA bits 24 — 27. (L=1) 
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11.28 Read Verify Sector(s) Ext (42h) 


Command Block Output Registers 
Reas pfe 4] 3, 
paatow HIT 


Data High f-|-]-]-[-| 
ewe FLL 
raw] |E 


Feature 


Sector Count 


Sector 
Number 


EE 
ag 


Cylinder Low 


Cylinder High 


ie 
comaa fo fos fof) 


V 
A 


Device/Head 


Error Register 


7 6 5 4 3 2 1 0 
CRC | UNC 0 IDN 0 ABT | TON | AMN 


pep 


Table 127 Read Verify Sector(s) Ext Command (42h) 


Command Block Input Registers 


paaro EE 
ation S 


Error 


HOB=0 
Sector Count 
HOB=1 


HOB=0 


HOB=1 


HOB=0 


HOB=1 


HOB=0 


HOB=1 
Device/Head 


Status Register 


7 6 5 4 3 2 1 
BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


HOGGE 


sJa[fsjz[ifol 
Hege 
eee 


... See Below... 


Sector 
Number 


Cylinder Low 


Cylinder High 


... See Below... 


The Read Verify Sector(s) Ext verifies one or more sectors on the device. No data is transferred to the host. 


The difference between the Read Sector(s) Ext command and the Read Verify Sector(s) Ext command is 


whether the data is transferred to the host or not. 


If an uncorrectable error occurs, the Read Verify Sector(s) Ext will be terminated at the failing sector. 
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Output Parameters To The Device 


Sector Count Current The number of continuous sectors to be verified low order, bits (7:0). 

Sector Count Previous The number of continuous sectors to be verified high order, bits (15:8). If zero 
is specified in the Sector Count register, then 65,536 sectors will be verified. 

Sector Number Current LBA (7:0). 

Sector Number Previous LBA (31:24) 

Cylinder Low Current LBA (15:8). 

Cylinder Low Previous LBA (39:32). 

Cylinder High Current LBA (23:16). 

Cylinder High Previous LBA (47:40). 

Input Parameters From The Device 

Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 

Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 

Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 

Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 

Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 

Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 
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11.29 Recalibrate (1xh) 


Command Block Output Registers 


Command Block Input Registers 


Register Register 7 6 5 4 3 2 
Data Data eS we eee 
Feature Error ... See Below... 
Sector Count Sector Count d Wee ee 
Sector Number - === 
Cylinder Low Cylinder Low S a As 
Cylinder High Cylinder High Se tes be 
Device/Head å pt OE cee ME ste Se 
Status ... See Below... 


Error Register 


Status Register 


7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 
CRCJUNC| 0 IDN 0 | ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


pA 


Table 128 Recalibrate Command (1xh) 


FRAMME 


The Recalibrate command moves the read/write heads from anywhere on the disk to cylinder 0. 


If the device cannot reach cylinder 0, TON (Track 0 Not Found) will be set in the Error Register. 
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11.30 Security Disable Password (F6h) 


Command Block Output Registers Command Block Input Registers 
Register 7 6 5 4 3 2 10 Register 7 6 5 4 3 2 10 


Data Data av fer cer ey ce eo vår i 
Error ... See Below... 

Sector Count 2 ona a OG er 
Sector Number | - - - - - - == 
Cylinder Low Cylinder Low BG å DANE G 


Cylinder High Cylinder High ut yey ute, ee NE ber, So 


Device/Head Device/Head - eee 
A ot - a) od Status ... See Below... 


7 6 5 4 3 
BSY | RDY | DF |DSC}DRQ|C 
ee] 


Table 129 Security Disable Password Command (F6h) 


aa) 


The Security Disable Password command disables the security mode feature (device lock function). 


The Security Disable Password command requests a transfer of a single sector of data from the host including 
information specified in Table 128 on the page 169. Then the device checks the transferred password. If the 
User Password or Master Password matches the given password, the device disables the security mode feature 
(device lock function). This command does not change the Master Password which may be re-activated later by 
setting User Password. This command should be executed in device unlock mode. 


When security is disabled and the Identifier bit is set to User, then the device shall return command aborted. 
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[Word [Description == 


Control word 
bit 0 : Identifier (1-Mater, 0-User) 
bit 1-15 : Reserved 


Password (32 bytes) 


Reserved 


Table 130 Password Information for Security Disable Password command 


The device will compare the password sent from this host with that specified in the control word. 


Identifier Zero indicates that the device should check the supplied password against the user password 
stored internally. One indicates that the device should check the given password against the 
master password stored internally. 
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11.31 Security Erase Prepare (F3h) 


Command Block Output Registers Command Block Input Registers 
Register |7 6 5 43210 Register 7 65 4 3 2 10 


ais i i i i å i i i 
Error ...See Below... 


Sector Count Bi ee est By eve OG 2 


Sector Number | - - - - - - == 


Cylinder Low Cylinder Low Er å gee Ge, tee, oe 
Cylinder High Cylinder High ee ee oe ea 


Device/Head 1 - 1 D - - - - Device/Head - eee 
[Command | 1 1 1 001 1 Status ...See Below... 


7 6 
CRC | UNC 


Table 131 Security Erase Prepare Command (F3h) 


The Security Erase Prepare Command must be issued immediately before the Security Erase Unit Command to 
enable device erasing and unlocking. 


The Security Erase Prepare Command must be issued immediately before the Format Unit Command. This 
command is to prevent accidental erasure of the device. 


This command does not request to transfer data. 
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11.32 Security Erase Unit (F4h) 


ae ee 
fmm | 
awe [oo 
sens [ 
a 
E 


Command Block Input Registers 


MENE 


Error See Below 


wen fo 
n 
omme [oo 
Sere 
See 


Device/Head 


Cylinder High 
Device/Head 


Status Register 


7 6 5 4 3 2 1 0 


Error Register 


7 6 2 1 0 


BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


Table 132 Security Erase Unit Command (F4h) 


The Security Erase Unit command initializes all user data sectors, and then disables the device lock function. 


Note that the Security Erase Unit command initializes from LBA 0 to Native MAX LBA. Host MAX LBA set by 
Initialize Drive Parameter, Device Configuration Overlay, or Set MAX Address command is ignored. So the 
protected area by Set MAX Address command is also initialized. 


This command requests to transfer a single sector data from the host including information specified in Table 
132 on the page 173. 


When security is disabled and the Identifier bit is set to User, then the device shall return command aborted. 
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If the password does not match, then the device rejects the command with an Aborted error. 


Word Description 
00 Control word 
bit 0 : Identifier (1-Mater, 0-User) 
bit 1 : Erase mode (1- Enhanced, 0- Normal) 
Enhanced mode is not supported 

bit 2-15 : Reserved 

01-16 Password (32 bytes) 

17-255 Reserved 


Table 133 Erase Unit Information 


Identifier Zero indicates that the device should check the supplied password against the user 
password stored internally. One indicates that the device should check the given password 
against the master password stored internally. 


The Security Erase Unit command erases all user data and disables the security mode feature (device lock 
function). So after completing this command, all user data will be initialized to zero with write operation. At this 
time, it is not verified with read operation whether the sector of data is initialized correctly. Also, the defective 
sector information and the reassigned sector information for the device are not updated. The security erase 
prepare command should be completed immediately prior to the Security Erase Unit command. If the device 
receives a Security Erase Unit command without a prior Security Erase Prepare command, the device aborts the 
security erase unit command. 


This command disables the security mode feature (device lock function), however the master password is still 
stored internally within the device and may be re-activated later when a new user password is set. If you execute 
this command on disabling the security mode feature (device lock function), the password sent by the host is 
NOT compared with the password stored in the device for both the Master Password and the User Password, 
and then the device only erases all user data. 


The execution time of this command is set in word 89 of Identify device information. 
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11.33 Security Freeze Lock (F5h) 


Command Block Output Registers Command Block Input Registers 
Register |7 6 5 43210 Register 7 65 4 3 2 10 


a e Error ... See Below... 
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BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


ARAE 


Table 134 Security Freeze Lock Command (F5h) 


The Security Freeze Lock Command allows the device to enter frozen mode immediately. 


After this command is completed, the command which updates Security Mode Feature (Device Lock Function) is 
rejected. 


Frozen mode is quit only by Power off. 


The following commands are rejected when the device is in frozen mode. For detail, refer to Table 36 and Table 
37 on the page 5859. 


Security Set Password 
Security Unlock 

Security Disable Password 
Security Erase Unit 
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11.34 Security Set Password (F1h) 


Command Block Output Registers Command Block Input Registers 
Register 7 6 5 4 3 2 10 Register 7 6 5 4 3 2 10 


Data Data Mur Yo) Ug, TEEN fa. te 
Feature Error ... See Below... 

Sector Count Sector Count Gr See, GY. Sea CEN eee ser? å 
Sector Number Sector Number | - - - - - - == 
Cylinder Low Cylinder Low EE 
Cylinder High Cylinder High Safe Lig Sm Uae. ede å ae 


Device/Head Device/Head - eee 


Command 
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1 Status ... See Below... 


Status Register 


7 6 5 4 3 2 1 0 
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CRC | UNC 
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Table 135 Security Set Password Command (F1h) 


The Security Set Password command enables security mode feature (device lock function), and sets the master 
password or the user password. 


The security mode feature (device lock function) is enabled by this command, and the device is not locked 
immediately. The device is locked after next power on reset. When the MASTER password is set by this 
command, the master password is registered internally, but the device is NOT locked after next power on reset 
or hard reset. 


This command requests a transfer of a single sector of data from the host including the information specified in 
Table 135 on the page 176. 


The data transferred controls the function of this command. 
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Word Description 
00 Control word 
bit 0 : Identifier (1-Mater, 0-User) 
bit 1-7 : Reserved 
bit 8 : Security level 
(1-Maximum, 0-High) 
bit 9-15 : Reserved 
01-16 Password (32 byte) 
17 Master Password Revision Code 
(valid if Word 0 bit 0 = 1) 
18-255 Reserved 


Table 136 Security Set Password Information 


Identifier Zero indicates that the device regards Password as User Password. One indicates 
that device regards Password as Master Password. 


Security Level Zero indicates High level, one indicates Maximum level. If the host sets High level 
and the password is forgotten, then the Master Password can be used to unlock the 
device. If the host sets Maximum level and the user password is forgotten, only an 
Security Erase Prepare/Security Unit command can unlock the device and all data 
will be lost. 


Password The text of the password — all 32 bytes are always significant. 


Master Password The revision code field is returned in the IDENTIFY DEVICE word 92. 

Revision Code The valid revision codes are 0001h through FFFEh. The device accepts the 
command with a value of 0000h or FFFFh in this field, but does not change Master 
Password Revision code. 


The setting of the Identifier and Security level bits interact as follows. 


Identifier=User / Security level = High 
The password supplied with the command will be saved as the new user password. The security mode feature 
(lock function) will be enabled from the next power on. The file may then be unlocked by either the user 
password or the previously set master password. 


Identifier=Master I Security level = High 
This combination will set a master password but will NOT enable the security mode feature (lock function). 


Identifier=User / Security level = Maximum 
The password supplied with the command will be saved as the new user password. The security mode feature 
(lock function) will be enabled from the next power on. The file may then be unlocked by only the user 
password. The master password previously set is still stored in the file but may NOT be used to unlock the 
device. 


Identifier=Master I Security level = Maximum 
This combination will set a master password but will NOT enable the security mode feature (lock function). 
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11.35 Security Unlock (F2h) 


Command Block Output Registers Command Block Input Registers 
Register |7 6 543210 Register 7 6 5 4 3 2 10 
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Table 137 Security Unlock Command (F2h) 


7 5 4 3 
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This command unlocks the password and causes the device to enter device unlock mode. If power on reset or 
hard reset is done without executing the Security Disable Password command after this command is completed, 
the device will be in device lock mode. The password has not been changed yet. 


The Security Unlock command requests to transfer a single sector of data from the host including information 
specified in Table 137 on the page 178. 


If the Identifier bit is set to master and the file is in high security mode then the password supplied will be 
compared with the stored master password. If the file is in maximum security mode then the security unlock will 
be rejected. 


If the Identifier bit is set to user, then the file compares the supplied password with the stored user password. 
If the password compare fails, then the device returns an abort error to the host and decrements the unlock 
attempt counter. This counter is initially set to 5 and is decremented for each password mismatch. 


When security is disabled and the Identifier bit is set to User, then the device shall return command aborted. 
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When this counter reaches zero then all password protected commands are rejected until a hard reset or a 
power off. 


Word Description 
00 Control word 
bit 0 : Identifier (1-Mater, 0-User) 
bit 1-15 : Reserved 
01-16 Password (32 bytes) 
17-255 Reserved 


Table 138 Security Unlock Information 


Identifier Zero indicates that device regards Password as User Password. One indicates that device 
regards Password as Master Password. 


The user can detect if the attempt to unlock the device has failed due to a mismatched password as this is the 
only reason that an abort error will be returned by the file AFTER the password information has been sent to the 
device. If an abort error is returned by the device BEFORE the password data has been sent to the file then 
another problem exists. 
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11.36 Seek (7xh) 


Command Block Output Registers 


a ee ee 


Command Block Input Registers 
6 5 4 3 2 1 0 


4 3 2 1 0 7 6 5 4 3 2 1 0 


7 6 5 
CRCIUNC| 0 IDN 0 | ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


Table 139 Seek Command (7xh) 


The Seek command initiates a seek to the designated track and selects the designated head. The device need 
not be formatted for a seek to execute properly. 

Output Parameters To The Device 

Sector Number In LBA mode, this register specifies LBA address bits 0 — 7 for seek. (L=1) 


Cylinder High/Low The cylinder number of the seek. 
In LBA mode, this register specifies LBA address bits 8 — 15 (Low), 16 — 23 (High) 
for seek. (L=1) 

H The head number of the seek. 
In LBA mode, this register specifies LBA address bits 24 — 27 for seek. (L=1) 


Input Parameters From The Device 


Sector Number In LBA mode, this register contains current LBA bits 0 — 7. (L=1) 

Cylinder High/Low In LBA mode, this register contains current LBA bits 8 — 15 (Low), 16 — 23 (High). 
(L=1) 

H In LBA mode, this register contains current LBA bits 24 — 27. (L=1) 
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11.37 Set Features (EFh) 


Command Block Output Registers 
Register 


Feature VV VV VV V V 


Command Block Input Registers 
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Sector Count 
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Command 
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Table 140 Set Features Command (EFh) 
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The Set Feature command is to establish the following parameters which affect the execution of certain features 
as shown in below table. 


ABT will be set to 1 in the Error Register if the Feature register contains any undefined values. 
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Output Parameters To The Device 
Feature Destination code for this command 
02H Enable write cache 
03H = Set transfer mode based on value in sector count register 
05H = Enable Advanced Power Management 
06H Enable Power-up in Standby feature set 
07H Power-Up In Standby feature set device spin-up 
10H Enable use of Serial ATA feature 
43H Set Maximum Host Interface Sector Time 
4Ah Extended Power Conditions 
55H Disable read look-ahead feature 
66H Disable reverting to power on defaults 
82H Disable write cache 
85H Disable Advanced Power Management 
86H Disable Power-up in Standby mode 
90H Disable use of Serial ATA feature 
AAH Enable read look-ahead feature 
CCH Enable reverting to power on defaults 


Note. 
After power on reset or hard reset, the device is set to the following features as default. 
Write cache : Enable 
Read look-ahead : Enable 
Reverting to power on defaults : Disable 
Release interrupt : Disable 
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11.37.1 Set Transfer mode 


When Feature register is 03h (=Set Transfer mode), the Sector Count Register specifies the transfer mechanism. 
The upper 5 bits define the type of transfer and the low order 3 bits encode the mode value. 


PIO Default Transfer Mode 00000 000 
PIO Default Transfer Mode 00000 001 
Disable IORDY 
PIO Flow Control Transfer Mode x 00001 nnn (nnn=000,001,010,011,100) 
Multiword DMA mode x 00100 nnn (nnn=000,001,010) 
Ultra DMA mode x 01000 nnn (nnn=000,001,010,011,100,101,11 


11.37.2 Write Cache 


0) 


If the number of auto reassigned sector reaches the device’s reassignment capacity, the write cache function 
will be automatically disabled. Although the device still accepts the Set Features command with Feature register 
= 02h without error, but the write cache function will remains disabled. For current write cache function status, 
please refer to Identify Device Information (word 85 or 129) by Identify Device command. 


11.37.3 Serial ATA Feature 


When the Feature register is set to 10h or 90h, the value set to the Sector Count register specifies the specific 
Serial ATA feature to enable or disable. 


Sector Count Value 
Olh 
02h 
03h 
04h 
O6h 


Description 
Non-zero buffer offset in DMA Setup FIS 
DMA Setup FIS Auto-Activate optimization 
Device-initiated interface power state transitions 
Guaranteed In-Order Data Delivery 


Software Settings Preservation 
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11.37.4 Advanced Power Management 


When the value in the Feature register is 05h (=Enable Advanced Power Management), the Sector Count 
Register specifies the Advanced Power Management level. 


FFh --- Aborted 
CO — Feh --- The deepest Power Saving mode is Normal Idle mode 

(the same as Disable Advanced Power Management) 
80 — BFh --- The deepest Power Saving mode is Low power Idle mode 
01 — 7Fh --- The deepest Power Saving mode is Low RPM standby mode 
OOh --- Aborted 


The idle time to Low power idle mode and Low RPM standby mode vary according to the value in Sector Count 
register as follows: 


When Low power idle mode is the deepest Power Saving mode, 
Y1=(x-80h) * 5+120 [sec] (120<= Y;<=435) 
Y-=N/A(the device does not go to Low RPM standby mode) 


When Low RPM standby mode is the deepest Power Saving mode and the value in Sector Count register is 
between 40h and 7Fh, 


120<=Y,<=435 [sec] (default: 120 [sec]) 
Y2=(x-40h) * 60 + 600[sec] (600<=Y2<=4380) 


When Low RPM standby mode is the deepest Power Saving mode and the value in Sector Count register is 
between 01h and 3Fh, 


120<=Y,<=435 [sec] (default: 120 [sec]) 
Y2=600 [sec] 


where x is the value in Sector Count register, y, is the idle time to Low Power Idle mode, and y; is the idle time 
to Low RPM standby mode. 


If Low power idle mode has already been enabled (i.e., yı has been set) before Low RPM standby mode is 
enabled, y, is preserved. If Low power idle mode is disabled (i.e., y, has not been set yet), yı becomes 120[sec] 
when Low RPM standby mode is enabled. 


Enabled Power Saving mode and idle time (y, and y2) are preserved until Advanced Power Management is 
disabled, the deepest Power Saving mode becomes Normal Idle mode, or new time is set. They are initialized 
with a hard/soft reset unless Reverting to power on defaults is disabled and the device receives a soft reset. 


11.37.4.1 Low Power Idle mode 


Additional electronics are powered off, and heads are unloaded on the ramp, however the spindle is still rotated 
at the full speed. 


11.37.4.2 Low RPM standby mode 


The heads are unloaded on the ramp, and the spindle is rotated at the 60-65% of the full speed. 


When Feature register is 85h (=Disable Advanced Power Management), the deepest Power Saving mode 
becomes normal Idle. 
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11.37.5 Set Maximum Host Interface Sector Time 


Sector Count Typical PIO Mode Host Interface Sector Time (7:0) 
LBA Low Typical PIO Mode Host Interface Sector Time (15:8) 
LBA Mid Typical DMA Mode Host Interface Sector Time (7:0) 
LBA High Typical DMA Mode Host Interface Sector Time (15:8) 


Subcommand code 43h allows the host to inform the device of a host interface rate limitation. The typical Host 
Interface Sector Times have the same units as Identify Device word 96 for DMA and word 104 for PIO. A value of 
zero indicates that the host interface shall be capable of transferring data at the maximum rate allowed by the 
selected transfer mode. The Typical PIO Mode Host Interface Sector Time includes the host’s interrupt service 
time. 
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11.37.6 Extended Power Conditions (EPC) feature 


11.37.6.1 Restore Power Condition Settings subcommand 


mrs 


Power Condition IDs 
BLG BG Table 66 Extended Power 
Conditions Subcommands 
Sector Paramater 
Number Table 141 


Error Register Status Register 


7 6 5 4 3 2 1 0) 7 6 5 4 3 2 1 0 
CRCJUNC| 0 IDN 0 | ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 
V V 


Table 141 Paramater 


Output Parameters To The Device 


bit Description 
6 Default 
1 Restore from Default settings 


0 Restore from Saved settings 
5 Reserved 
4 Save 

1 Save settings on completion 


0 Do not save settings on completion 


3-0 Restore Power Condition subcommand (0) Table 66 
Error Output 
If any selected Power Condition: 
a) is not supported. 
b) is not changeable. 
c) if Save is set to one and any selected power condition is not saveable, then the device shall return command 
aborted . 


Hitachi hard disk drive specifications 
186 


11.37.6.2 Go To Power Condition subcommand 


Command Block Output Registers Command Block Input Registers 
Register 7 6 5 4 3 2 1 0 Register 7 6 5 4 3 2 10 


Power Condition IDs 
Table 66 Extended Power Conditions 
Subcommands 


Error Register Status Register 
7 6 4 2 1 0) 


5 3 7 6 5 4 3 2 1 0 
CRCJUNC| 0 0 | ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


Error Output 
If the Power condition ID is FFh, a reserved value, or is not supported, then the device shall return command 
aborted . 
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11.37.6.3 Set Power Condition Timer subcommand 


Command Block Input Registers 
7 65 4 3 2 10 


Power Condition IDs 
Sector Count Table 66 Extended Power Sector Count 
Conditions Subcommands 
Sector Parameter Sector 
Number Table 142 Number 
Timer (15:0) 


Error Register Status Register 
4 3 2 1 0 


7 6 5 7 6 5 4 3 2 1 0 
CRCJUNC| 0 IDN 0 | ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


Timer(15:0) 

If the new timer value is greater than the maximum value setting, then the device may set the value to the 
maximum setting . If the new timer value is less than the minimum setting, then the device may set the value to 
the minimum setting. 


Timer Units 
If the Timer Units bit is cleared to zero, then the Timer (15:0) shall be specified in units of 100 milliseconds. If the 
Timer Units bit is set to one, then the Timer (15:0) shall be specified in units of 1 minute. 


Table 142 Paramater 


Output Parameters To The Device 


bit Description 
Timer Units 
Reserved 
Enable 
1 Enable the selected power condition 


aan 


0 Disable the selected power condition 
4 Save 
1 Save settings on completion 


0 Do not save settings on completion 
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3-0 Restore Power Condition subcommand (02h) Table 66 


Error Output 
The device shall return command aborted If: 
a) the new timer value is: 
A) less than the maximum setting. 
B) greater than the minimum setting. 
C) not supported by the device. 
b) the Power Condition field is invalid. 
c) the power condition is not changeable or not supported. 
d) the Save bit is set to one and the selected power condition is not saveable. 
e) the new time value is greater than the maximum setting and the device did not set the timer to the maximum 
setting. 
f) the new time value is less than the minimum setting and the device did not set the timer to the minimum 
setting. 
If command aborted is returned, then the device shall make no modifications to the power condition settings. 
Maximum Setting is FFFFh (100ms unit). Minimum Setting is zero. 
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11.37.6.4 Set Power Condition State subcommand 


Command Block Output Registers Command Block Input Registers 
fester |7 6 58 4 8 2 2 0 Register 7 65 4 3 2 10 


get eras 


Power Condition IDs 
Sector Count Table 66 Extended Power Sector Count 
Conditions Subcommands 
Sector Parameter Sector 
Number Table 143 Number 


Error Register Status Register 
4 3 2 1 0 


7 6 5 7 6 5 4 3 2 1 0 
CRCJUNC| 0 IDN 0 | ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


Table 143 Parameter 


Output Parameters To The Device 


bit Description 
5 Default 
1 Restore from Default settings 


0 Restore from Saved settings 
4 Save 
1 Save settings on completion 


0 Do not save settings on completion 
3-0 Restore Power Condition subcommand (03h) Table 66 


Error Output 


If the Power Condition is invalid, not changeable, or not supported then the device shall return command 
aborted. If the Save bit is set to one and the selected power condition is not saveable, then the device shall 
return command aborted. If command aborted is returned, then the device shall make no modifications to the 
power condition settings. 
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11.38 Set Max Address (F9h) 


Command Block Output Registers 


CE ee 
n 


Command Block Input Registers 
Register 7 6 5 4 3 2 1 0 


Sector Number | V V V V V V V V 


Status Register 


7 6 5 4 3 2 1 0 


Sector Count 


Cylinder High VV VV VV VV 
Device/Head 1 L 1 D H H H H 


7 6 5 4 3 


2 1 0 
CRC | UNC ABT | TON | AMN 


BSY | RDY | DF |DSC|DRQ|COR | IDX | ERR 


Table 144 Set Max ADDRESS (F9h) 


The device regards as Set Max Address command, if this command is immediately preceded by a Read Native 
Max Address command. The device receives this command without a prior Read Native Max Address command, 
the device regards as Set Max security extensions command according to feature register value. Valid features 
values are as follows: 


1. Oth indicates Set Max Set Password command 
2. 02h indicates Set Max Lock command 

3. 03h indicates Set Max Unlock command 

4. 04h indicates Set Max Freeze LOCK command 


This command overwrites the maximum number of Address of HDD in a range of actual device capacity. Once 
device receives this command, all accesses beyond that Address are rejected with setting ABORT bit in status 
register. Identify device command returns the Address which is set via this command as a default value. 


Device returns command aborted for a second non-volatile Set Max Address command until next power on or 
hardware reset. 


Device returns command aborted during Set Max Locked mode or Set Max Frozen mode. 


After a successful command completion, Identify Device response words (61:60) shall reflect the maximum 
address set with this command. 
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If the 48-bit Address feature set is supported, the value placed in Identify Device response words (103:100) shall 
be the same as the value placed in words (61:60). However, if the device contains greater than 268,435,455 
sectors, the capacity addressable with 28-bit commands, and the address requested is 268,435,455, the max 
address shall be changed to the native maximum address, the value placed in words (61:60) shall be 
268,435,455 and the value placed in words (103:100) shall be the native maximum address. 


If a host protected area has been established by a Set Max Address Ext command, the device shall return 


command aborted. 


Output Parameters To The Device 


B 


Sector Number 


Cylinder High/Low 


H 


Option bit for selection whether nonvolatile or volatile. B=0 is volatile condition. When 
B=1, MAX Address which is set by Set Max Address command is preserved by POR. 
When B=0, MAX Address which is set by Set Max Address command will be lost by 
POR. B=1 is not valid when the device is in Address Offset mode. 


In LBA mode, this register contains LBA bits 0 — 7 which is to be input.(L=1) 

In CHS mode, this register is ignored. (L=0) 

In LBA mode, this register contains LBA bits 8 — 15 (Low), 16 — 23 (High) which is to be 
set. (L=1) 

In CHS mode, this register contains cylinder number which is to be set.(L=0) 


In LBA mode, this register contains LBA bits 24 — 27 which is to be set.(L=1) 
In CHS mode, this register is ignored. (L=0) 


Input Parameters From The Device 


Sector Number 


Cylinder High/Low 


In LBA mode, this register contains max LBA bits 0 — 7 which is set.(L=1) 
In CHS mode, this register contains max sector number (= 63). (L=0) 


In LBA mode, this register contains max LBA bits 8 — 15 (Low), 16 — 23 (High) which is 
set. (L=1) 
In CHS mode, this register contains max cylinder number which is set. (L=0) 


In LBA mode, this register contains max LBA bits 24 — 27 which is set. (L=1) 
In CHS mode, this register contains max head number.(L=0) 
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11.38.1 Set Max Set Password (Feature = 01h) 


Command Block Input Registers 
Register 7 6 5 4 3 2 10 


Data 


Error ... See Below... 


Ce serer 
a [ 
re [oo 
om [ 
EE 
re 


Sector Count rd å 
Sector Number HETTE 


Error Register 


7 6 2 1 0 


Cylinder High 


Device/Head 


Status Register 


7 6 5 4 3 2 1 
BSY | RDY | DF | DSC | DRQ | COR 


<|8 > 


Table 145 Set Max set Password 


The device regards as Set Max Address command, if this command is immediately preceded by a Read Native 
Max Address command. 


This command requests a transfer of a single sector of data from the host including the information specified in 
Table 145. 


The password is retained by the device until the next power cycle. When the device accepts this command the 
device is in Set_Max_Unlocked state. 


(Word [Description SSCS 


Reserved 


Password (32 byte) 
Reserved 


Table 146 Set Max Set Password data contents 
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11.38.2 Set Max Lock (Feature = 02h) 


pe fm Jo 
Sector Count 


Cylinder High Cylinder High 


Status Register 


7 6 5 4 2 1 0 7 6 5 4 3 2 1 0 
CRCJUNC| 0 IDN ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 
FN PN 


Table 147 Set Max Lock 


The device regards as Set Max Address command, if this command is immediately preceded by a Read Native 
Max Address command. 


This command sets the device into Set Max Locked state. After this command is completed any other Set Max 
commands except Set Max Unlock and Set Max Freeze Lock are rejected. The device remains in this state until 
a power cycle or the acceptance of a Set Max Unlock or Set Max Freeze Lock command. 
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11.38.3 Set Max Unlock (Feature = 03h) 


ee ees | (ae eee! 


Sector Count 
Sector Number 


Cylinder High Cylinder High 
Device/Head 1 - 1 D - - - - Device/Head 
7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 
ABT | TON | AMN BSY | RDY | DF |DSC}DRQ|COR] IDX | ERR 


Table 148 Set Max Unlock (F9h) 


The device regards as Set Max Address command, if this command is immediately preceded by a Read Native 
Max Address command. 


This command requests a transfer of a single sector of data from the host including the information specified in 
Table 145 on the page 193 with the stored SET MAX password. 


If the password compare fails then the device returns an abort error to the host and decrements the unlock 
attempt counter. This counter is initially set to 5 and is decremented for each password mismatch. When this 
counter reaches zero then all Set Max Unlock commands are rejected until a hard reset or a power off. 


If the password compares matches, then the device set the Set_Max_Unlocked state and all Set Max 
commands shall be accepted. 
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11.38.4 Set Max Freeze Lock (Feature = 04h) 


ee | ome J-->>> 

mem | fem] 

seere (me 

omer [| fom | 
ATT [ome ore gone 
rere 


Sector Count 
Sector Number 


Cylinder High Cylinder High 
Device/Head 1 - 1D - - - - Device/Head 


Error Register Status Register 


i 6 5 4 3 2 1 0) 7 6 5 4 3 2 1 0 


ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


Table 149 Set Max Freeze Lock (F9h) 


The device regards as Set Max Address command, if this command is immediately preceded by a Read Native 
Max Address command. 


The Set Max Freeze Lock command sets the device to Set_Max_Frozen state. After command completion any 
subsequent Set Max commands are rejected. Commands disabled by Set Max Freeze Lock are: 


1. Set Max Address 

2. Set Max Set PASSWORD 
3. Set Max Lock 

4. Set Max Unlock 
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11.39 Set Max Address Ext (37h) 


command soopaa — 
reser Ea OE 0 BEE 
w 
bata ne Maie ale 

ee 
me ett 


mm TEE Te 
Se HØRE 


Sector 
Number 


Command Block Input Registers 
neger peee eee 
aaron > PPT 


EE 


Sector Count 


mm ode 
Number = v] v] 
Cylinder Low E 

aa aR viv] 
i 

GA a 
pest Mek 


Sas eo een 


Current fvjviv[vlvfv|vfv] 
mer e E EEEE EE 
7 raser vfefvheffepr 
Ken EE KN 
prema ENE 
NNN 


Error Register 


PARABEL 


Table 150 Set Max Address Ext Command a 


Status = 


HENARES 


This command is immediately preceded by a Read Native Max Address Ext command. 


This command overwrites the maximum number of Address of HDD in a range of actual device capacity. Once 
device receives this command, all accesses beyond that Address are rejected with setting ABORT bit in status 
register. 


When the address requested is greater than 268,435,455, words (103:100) shall be modified to reflect the 
requested value, but words (61:60) shall not be modified. When the address requested is equal to or less than 
268,435,455, words (103:100) shall be modified to reflect the requested value, and words (61:60) shall also be 
modified. 
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If this command is not supported, the maximum value to be set exceeds the capacity of the device, a host 
protected area has been established by a Set Max Address command, the command is not immediately 
preceded by a Read Native Max Address Ext command, or the device is in the Set Max Locked or Set Max 
Frozen state, the device shall return command aborted. 


The device returns the command aborted for a second non-volatile Set Max Address Ext command until next 
power on or hardware reset. 


Output Parameters To The Device 


B Option bit for selection whether nonvolatile or volatile. B=0 is volatile condition. 
When B=1, MAX Address which is set by Set Max Address Ext command is 
preserved by POR. When B=0, MAX Address which is set by Set Max Address 
Ext command will be lost by POR. B=1 is not valid when the device is in Address 
Offset mode. 


Sector Number Current Set Max LBA (7:0). 
Sector Number Previous Set Max LBA (31:24). 
Cylinder Low Current Set Max LBA (15:8). 
Cylinder Low Previous Set Max LBA (39:32). 
Cylinder High Current Set Max LBA (23:16). 
Cylinder High Previous Set Max LBA (47:40). 


Input Parameters From The Device 
Sector Number (HOB=0) Set Max LBA (7:0). 
Sector Number (HOB=1) Set Max LBA (31:24). 


Cylinder Low (HOB=0) Set Max LBA (15:8). 

Cylinder Low (HOB=1) Set Max LBA (39:32). 
Cylinder High (HOB=0) Set Max LBA (23:16). 
Cylinder High (HOB=1) Set Max LBA (47:40). 


Hitachi hard disk drive specifications 
198 


11.40 Set Multiple (C6h) 


Command Block Output Registers Command Block Input Registers 


ee ffm fo 
ewe | 
em [oo 
need [amie [on 
omme [| [oom [oe 
Device/Head Device/Head MITTE 


Status Register 


7 6 5 4 3 2 1 0 
BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


Table 151 Set Multiple Command (C6h) 


The Set Multiple command enables the device to perform Read and Write Multiple commands and establishes 
the block size for these commands. The block size is the number of sectors to be transferred for each interrupt. 


If an invalid block size is specified, an Abort error will be returned to the host, and Read Multiple and Write 
Multiple commands will be disabled. 


Output Parameters To The Device 

Sector Count. The block size to be used for Read Multiple and Write Multiple commands. Valid block 
sizes can be selected from 0, 1, 2, 4, 8 or 16. If 0 is specified, then Read Multiple and 
Write Multiple commands are disabled. 
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11.41 Sleep (E6h/99h) 


Command Block Input Registers 

Fre ee Error ... See Below... 

som [oo 

ef 
Berte 
par 


Sector Count fe pr NE ER a te ee 


Sector Number Bo pa «a. i. ses oN cP g 


Cylinder Low a 

Cylinder High Cylinder High ee ee ee O 
Device/Head -= -= s 2-2 =s 2- =- č - 
Status ... See Below... 


Error Register 


7 6 5 4 3 2 1 0 
CRCJUNC| 0 IDN 0 | ABT | TON | AMN 
BHP 


Table 152 Sleep Command (E6h/99h) 


Status Register 


7 6 5 4 3 2 1 0 


BSY | RDY | DF | DSC |DRQ|COR | IDX | ERR 


PS Ee ee 


This command causes the device to enter Sleep Mode. 


The device is spun down and the interface becomes inactive. If the device is already spun down, the spin down 
sequence is not executed. 


The only way to recover from Sleep Mode is with a software reset or a hardware reset. 
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11.42 SMART Function Set (BOh) 


Command Block Output Registers Command Block Input Registers 


Cylinder Low Cylinder Low 

Cylinder High Cylinder High 
Device/Head 
Status 


Status Register 
7 6 5 4 3 2 1 (0) 


BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


Table 153 SMART Function Set Command (BOh) 


The SMART Function Set command provides access to Attribute Values, Attribute Thresholds and other low 
level subcommands that can be used for logging and reporting purposes and to accommodate special user 
needs. The SMART Function Set command has several separate subcommands which are selectable via the 
device’s Features Register when the SMART Function Set command is issued by the host. 
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11.42.1 SMART Subcommand 


In order to select a subcommand the host must write the subcommand code to the device’s Features Register 
before issuing the SMART Function Set command. The subcommands and their respective codes are listed 
below. 


Code Subcommand 

DOh SMART Read Attribute Values 

Dih SMART Read Attribute Thresholds 

D2h SMART Enable/disable Attribute Autosave 
D3h SMART Save Attribute Values 

D4h SMART Execute Off-line Immediate 

D5h SMART Read Log Sector 

D6h SMART Write Log Sector 

D8h SMART Enable Operations 

D9h SMART Disable Operations 

Dah SMART Return Status 

DBh SMART Enable/Disable Automatic Off-Line 


11.42.1.1 SMART Read Attribute Values (Subcommand DOh) 


This subcommand returns the device’s Attribute Values to the host. Upon receipt of the SMART Read Attribute 
Values subcommand from the host, the device saves any updated Attribute Values to the Attribute Data sectors, 
and then transfers the 512 bytes of Attribute Value information to the host. 


11.42.1.2 SMART Read Attribute Thresholds (Subcommand D1h) 


This subcommand returns the device’s Attribute Thresholds to the host. Upon receipt of the SMART Read 
Attribute Thresholds subcommand from the host, the device reads the Attribute Thresholds from the Attribute 
Threshold sectors, and then transfers the 512 bytes of Attribute Thresholds information to the host. 


11.42.1.3 SMART Enable/Disable Attribute Autosave (Subcommand D2h) 


This subcommand enables and disables the attribute autosave feature of the device. The SMART 
Enable/Disable Attribute Autosave subcommand either allows the device to automatically save its updated 
Attribute Values to the Attribute Data Sector periodically; or this subcommand causes the autosave feature to be 
disabled. The state of the Attribute Autosave feature (either enabled or disabled) will be preserved by the device 
across power cycle. 


A value of OOh written by the host into the device’s Sector Count Register before issuing the SMART 
Enable/Disable Attribute Autosave subcommand will cause this feature to be disabled. Disabling this feature 
does not preclude the device from saving Attribute Values to the Attribute Data sectors during some other 
normal operation such as during a power-up or power-down. 


A value of Fih written by the host into the device's Sector Count Register before issuing the SMART 
Enable/Disable Attribute Autosave subcommand will cause this feature to be enabled. Any other non-zero value 
written by the host into this register before issuing the SMART Enable/Disable Attribute Autosave subcommand 
will not change the current Autosave status but the device will respond with the error code specified in 0. 


The SMART Disable Operations subcommand disables the autosave feature along with the device's SMART 
operations. 


Upon the receipt of the subcommand from the host, the device asserts BSY, enables or disables the Autosave 
feature, clears BSY and asserts INTRQ. 
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11.42.1.4 SMART Save Attribute Values (Subcommand D3h) 


This subcommand causes the device to immediately save any updated Attribute Values to the device’s Attribute 
Data sector regardless of the state of the Attribute Autosave feature. Upon receipt of the SMART Save Attribute 
Values subcommand from the host, the device writes any updated Attribute Values to the Attribute Data sector. 


11.42.1.5 SMART Execute Off-line Immediate (Subcommand D4h) 


This subcommand causes the device to immediately initiate the set of activities that collect Attribute data in an 
off-line mode (off-line routine) or execute a self-test routine in either captive or off-line mode. 


The Sector Number register shall be set to specify the operation to be executed. 


Sector Number Operation to be executed 


0 Execute SMART off-line data collection routine immediately 

1 Execute SMART Short self-test routine immediately in off-line mode 

2 Execute SMART Extended self-test routine immediately in off-line mode 
4 Execute SMART Selective self-test routine immediately in off-line mode 
127 Abort off-line mode self-test routine 

129 Execute SMART Short self-test routine immediately in captive mode 
130 Execute SMART Extended self-test routine immediately in captive mode 
132 Execute SMART Selective self-test routine immediately in captive mode 


Off-line mode: The device executes command completion before executing the specified routine. During 
execution of the routine the device will not set BSY nor clear DRDY. If the device is in the process of performing 
its routine and is interrupted by a new command from the host, the device will abort or suspend its routine and 
service the host within two seconds after receipt of the new command. After servicing the interrupting command, 
the device will resume its routine automatically or not start its routine depending on the interrupting command. 


Captive mode: When executing self-test in captive mode, the device sets BSY to one and executes the 
specified self-test routine after receipt of the command. At the end of the routine, the device sets the execution 
result in the Self-test execution status byte (0) and ATA registers as below and executes command completion. 


Status Set ERR to one when self-test has failed 
Error Set ABRT to one when self-test has failed 
Cyl Low Set to F4h when self-test has failed 

Cyl High Set to 2Ch when self-test has failed 
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11.42.1.6 SMART Read Log Sector (Subcommand D5h) 


This command returns the specified log sector contents to the host. 


The 512 bytes data are returned at a command and the Sector Count value shall be set to one. The Sector 
Number shall be set to specify the log sector address. 


SMART Self-test Log Read Only 


Selective self-test Log Read/Write 


80h-9Fh Host vendor specific Read/Write 


Note: Log addresses 03h and 07h are used by the Read Log Ext and Write Log Ext commands. If these log 
addresses are used with the SMART Read Log Sector command, the device shall return command aborted. 


Table 154 Log sector addresses 


11.42.1.7 SMART Write Log Sector (Subcommand D6h) 


This command writes 512 bytes data to the specified log sector. 


The 512 bytes data are transferred at a command and the Sector Count value shall be set to one. The Sector 
Number shall be set to specify the log sector address (0). If Read Only log sector is specified, the device returns 
ABRT error 


11.42.1.8 SMART Enable Operations (Subcommand D8h) 


This subcommand enables access to all SMART capabilities within the device. Prior to receipt of a SMART 
Enable Operations subcommand, Attribute Values are neither monitored nor saved by the device. The state of 
SMART (either enabled or disabled) will be preserved by the device across power cycles. Once enabled, the 
receipt of subsequent SMART Enable Operations subcommands will not affect any of the Attribute Values. 


Upon receipt of the SMART Enable Operations subcommand from the host, the device enables SMART 
capabilities and functions, and then saves any updated Attribute Values to the Attribute Data sector. 


11.42.1.9 SMART Disable Operations (Subcommand D9h) 


This subcommand disables all SMART capabilities within the device including the device’s attribute autosave 
feature. After receipt of this subcommand the device disables all SMART operations. Non self-preserved 
Attribute Values will no longer be monitored. The state of SMART (either enabled or disabled) is preserved by 
the device across power cycles. 


Upon receipt of the SMART Disable Operations subcommand from the host, the device disables SMART 
capabilities and functions, and then saves any updated Attribute Values to the Attribute Data sector. 


After receipt of the device of the SMART Disable Operations subcommand from the host, all other SMART 
subcommands — with the exception of SMART Enable Operations — are disabled, and invalid and will be aborted 
by the device (including the SMART Disable Operations subcommand), returning the error code as specified in 
0 on the page 218. 


Any Attribute Values accumulated and saved to volatile memory prior to receipt of the SMART Disable 
Operations command will be preserved in the device’s Attribute Data Sectors. If the device is re-enabled, these 
Attribute Values will be updated, as needed, upon receipt of a SMART Read Attribute Values or SMART Save 
Attribute Values command. 


Hitachi hard disk drive specifications 
204 


11.42.1.10 SMART Return Status (Subcommand Dah) 


This command is used to communicate the reliability status of the device to the host’s request. Upon receipt of 
the SMART Return Status subcommand the device saves any updated Pre-failure type Attribute Values to the 
reserved sector and compares the updated Attribute Values to the Attribute Thresholds. 


If the device does not detect a Threshold Exceeded Condition, the device loads 4Fh into the Cylinder Low 
register, C2h into the Cylinder High register. 


If the device detects a Threshold Exceeded Condition, the device loads F4h into the Cylinder Low register, 2Ch 
into the Cylinder High register. 


11.42.1.11 SMART Enable/Disable Automatic Off-Line (Subcommand DBh) 


This subcommand enables and disables the optional feature that causes the device to perform the set of off-line 
data collection activities that automatically collect attribute data in an off-line mode and then save this data to the 
device’s non-volatile memory. This subcommand may either cause the device to automatically initiate or resume 
performance of its off-line data collection activities or cause the automatic off-line data collection feature to be 
disabled. 


A value of zero written by the host into the device’s Sector Count Register before issuing this subcommand shall 
cause the feature to be disabled. Disabling this feature does not preclude the device from saving attribute values 
to non-volatile memory during some other normal operation such as during a power-on or power-off sequence or 
during an error recovery sequence. 


A value of F8h written by the host into the device’s Sector Count Register before issuing this subcommand shall 
cause this feature to be enabled. Any other non-zero value written by the host into this register before issuing 
this subcommand is vender specific and will not change the current Automatic Off-Line Data Collection, but the 
device may respond with the error code specified in 0 on the page.218 
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11.42.2 Device Attributes Data Structure 


The following defines the 512 bytes that make up the Attribute Value information. This data structure is 
accessed by the host in its entirety using the SMART Read Attribute Values subcommand. All multi-byte fields 
shown in these data structures are in byte ordering, namely that the least significant byte occupies the lowest 


numbered byte address location in the field. 


Description 
Data Structure Revision Number 
1* Device Attribute 


30" Device Attribute 

Off-line data collection status 

Self-test execution status 

Total time in seconds to complete off-line data collection activity 
Vender specific 

Off-line data collection capability 

SMART capability 

SMART device error logging capability 


e[ mm — 
‘a rns 
a 
ef mea] 
sam 
DE [ 
isen] 
sen] —— 


Self-test failure check point 173h mm 
Shart self-test completion time in minutes 174h nm 


Extended self-test completion time in minutes. If OFFh, use bytes 177h and 178h for 
completion time. 


Reserved 


Extended self-test completion time in minutes. (word) 
Reserved 

Vendor specific 125 
Data structure checksum 


Table 155 Device Attribute Data Structure 


11.42.2.1 Data Structure Revision Number 


The Data Structure Revision Number identifies which version of this data structure is implemented by the device. 
This revision number identifies both the Attribute Value and Attribute Threshold Data structures. 
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11.42.2.2 Individual Attribute Data Structure 


The following defines the 12 bytes that make up the information for each Attribute entry in the Device Attribute 
Data Structure. 


Attribute ID Number (01h to FFh) ORR 


Attribute Value (valid values from 01h to FDh) 


Table 156 Individual Attribute Data Structure 


Attribute ID Numbers: Any non-zero value in the Attribute ID Number indicates an active attribute. The device 
supports following Attribute ID Numbers. 


Attribute Name 

Indicates that this entry in the data structure is not used 
Raw Read Error Rate 
Throughput Performance 
Spin Up Time 

Start/Stop Count 
Reallocated Sector Count 
Seek Error Rate 

Seek Time Performance 
Power-On Hours Count 

10 Spin Retry Count 

12 Device Power Cycle Count 
192 Power off Retract count 


o 


COON Oo RWNR OO 


193 Load Cycle count 
194 Temperature 


196 Reallocation Event Count 

197 Current Pending Sector Count 

198 Off-Line Scan Uncorrectable Sector Count 
199 Ultra DMA CRC Error Count 


Status Flag Definitions 


Bit Definition 
0 Pre-failure/advisory bit 
0 An Attribute Value less than or equal to its corresponding Attribute Threshold indicates an 
advisory condition where the usage or age of the device has exceeded its intended design 
life period. 
1 An Attribute Value less than or equal to its corresponding attribute threshold indicates a 
pre-Failure condition where imminent loss of data is being predicted. 
1 On-Line Collective bit 
0 The Attribute Value is updated only during Off-Line testing 
1 The Attribute Value is updated during On-Line testing or during both On-Line and Off-Line 
testing. 


2-5 Vendor specific 
6-15 Reserved (0) 
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Normalized Values: The device will perform conversion of the raw Attribute Values to transform them into 
normalized values, which the host can then compare with the Threshold values. A Threshold is the excursion 
limit for a normalized Attribute Value. 


11.42.2.3 Off-Line Data Collection Status 


The value of this byte defines the current status of the off-line activities of the device. Bit 7 indicates Automatic 
Off-Line Data Collection Status. 


Bit 7 Automatic Off-Line Data Collection Status 

0 Automatic Off-Line Data Collection is disabled. 

1 Automatic Off-Line Data Collection is enabled. 

Bits 0 thru 6 represents a hexadecimal status value reported by the device. 


Value Definition 
Off-line data collection never started 


All segments completed without errors. 
Off-line data collection suspended by interrupting command 


Off-line data collecting aborted by interrupting command 


O no Aà N Oo 


Off-line data collection aborted with fatal error 


11.42.2.4 Self-test execution status 
Bit Definition 
0-3 Percent Self-test remaining 


An approximation of the percent of the self-test routine remaining until completion in ten percent 
increments. Valid values are O through 9. 


4-7 Current Self-test execution status 
The self-test routine completed without error or has never been run 


The self-test routine aborted by the host 

The self-test routine interrupted by the host with a hard or soft reset 

The device was unable to complete the self-test routine due to a fatal error or unknown test error 
The self-test routine completed with unknown element failure 

The self-test routine completed with electrical element failure 

The self-test routine completed with servo element failure 


NO oO BR WN FP O 


The self-test routine completed with read element failure 
The self-test routine in progress 


11.42.2.5 Total Time in Seconds to Complete Off-line Data Collection Activity 


This field tells the host how many seconds the device requires completing the off-line data collection activity. 


pp 
UT 
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11.42.2.6 Off-Line Data Collection Capability 


Bit 
0 


Definition 

Execute Off-line Immediate implemented bit 

0 SMART Execute Off-line Immediate subcommand is not implemented 

1 SMART Execute Off-line Immediate subcommand is implemented 

Enable/disable Automatic Off-line implemented bit 

0 SMART Enable/disable Automatic Off-line subcommand is not implemented 

1 SMART Enable/disable Automatic Off-line subcommand is implemented 

abort/restart off-line by host bit 

0 The device will suspend off-line data collection activity after an interrupting command and 
resume it after some vendor specific event 

1 The device will abort off-line data collection activity upon receipt of a new command 


Off-line Read Scanning implemented bit 

0 The device does not support Off-line Read Scanning 
1 The device supports Off-line Read Scanning 
Self-test implemented bit 

0 Self-test routine is not implemented 

1 Self-test routine is implemented 

Reserved (0) 

Selective self-test implemented bit 

0 Selective self-test routine is not implemented 

1 Selective self-test routine is implemented 


11.42.2.7 SMART Capability 


This word of bit flags describes the SMART capabilities of the device. The device will return 03h indicating that 
the device will save its Attribute Values prior to going into a power saving mode and supports the SMART 
ENABLE/DISABLE ATTRIBUTE AUTOSAVE command. 


Bit 
0 


2-15 


Definition 
Pre-power mode attribute saving capability 


If bit = 1, the device will save its Attribute Values prior to going into a power saving mode (Standby or 
Sleep mode). 

Attribute autosave capability 

If bit = 1, the device supports the SMART ENABLE/DISABLE ATTRIBUTE AUTOSAVE command. 


Reserved (0) 


11.42.2.8 Error Logging Capability 


Bit 
7-1 
0 


Definition 
Reserved (0) 


Error Logging support bit 
If bit = 1, the device supports the Error Logging 
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11.42.2.9 Self-test failure check point 

This byte indicates the section of self-test where the device detected a failure. 
11.42.2.10 Self-test completion time 

These bytes are the minimum time in minutes to complete self-test. 
11.42.2.11 Data Structure Checksum 


The Data Structure Checksum is the 2’s compliment of the result of a simple 8-bit addition of the first 511 bytes 
in the data structure. 
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11.42.3 Device Attribute Thresholds Data Structure 


The following defines the 512 bytes that make up the Attribute Threshold information. This data structure is 
accessed by the host in its entirety using the SMART Read Attribute Thresholds. All multi-byte fields shown in 
these data structures follow the ATA/ATAPI-7 specification for byte ordering, namely that the least significant 
byte occupies the lowest numbered byte address location in the field. 


The sequence of active Attribute Thresholds will appear in the same order as their corresponding Attribute 
Values. 


[oescepion [mes [ona [vau | 


Data Structure Revision Number 0010h 


30" Atribute Threshold En] ——| 
16AN 
Vendor specific 17Ch 


EE 


Table 157 Device Attribute Thresholds Data Structure 


11.42.3.1 Data Structure Revision Number 
This value is the same as the value used in the Device Attributes Values Data Structure. 
11.42.3.2 Individual Thresholds Data Structure 


The following defines the 12 bytes that make up the information for each Threshold entry in the Device Attribute 
Thresholds Data Structure. Attribute entries in the Individual Threshold Data Structure are in the same order and 
correspond to the entries in the Individual Attribute Data Structure. 


Total Bytes 


Table 158 Individual Threshold Data Structure 


11.42.3.3 Attribute ID Numbers 

Attribute ID Numbers supported by the device are the same as Attribute Values Data Structures. 
11.42.3.4 Attribute Threshold 

These values are preset at the factory and are not meant to be changeable. 

11.42.3.5 Data Structure Checksum 


The Data Structure Checksum is the 2’s compliment of the result of a simple 8-bit addition of the first 511 bytes 
in the data structure. 
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11.42.4 SMART Log Directory 


Table 159 defines the 512 bytes that make up the SMART Log Directory. The SMART Log Directory is SMART 
Log Address zero and is defined as one sector long. 


Table 159 SMART Log Directory 


The value of the SMART Logging Version word shall be 01h. The logs at log addresses 80-9Fh shall each be 
defined as 16 sectors long. 
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11.42.56 SMART summary error log sector 


The following defines the 512 bytes that make up the SMART summary error log sector. All multi-byte fields 
shown in this data structure follow the ATA/ATAPI-7 specifications for byte ordering. 


Table 160 SMART summary error log sector 


11.42.5.1 SMART error log version 

This value is set to O1h. 

11.42.5.2 Error log index 

This points the most recent error log data structure. Only values 1 through 5 are valid. 
11.42.5.3 Device error count 


This field contains the total number of errors. The value will not roll over. 
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11.42.5.4 Error log data structure 


Data format of each error log structure is shown below. 


1° error log data structure 


Sl 
n 


t 
h 
h 


4" error log data structure 
5" error log data structure 
Error data structure 


Table 161 Error log data structure 


Command data structure: Data format of each command data structure is shown below. 


Timestamp (milliseconds from Power On) 4 08h 


fa 


Table 162 Command data structure 
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Error data structure: Data format of error data structure is shown below. 


Table 163 Error data structure 


State field contains a value indicating the device state when command was issued to the device. 


Value State 

x0h Unknown 

xih Sleep 

x2h Standby 

x3h Active/Idle 

x4h SMART Off-line or Self-test 


x5h-xAh Reserved 
xBh-xFh Vendor specific 


Note: The value of x is vendor specific. 
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11.42.6 Self-test log data structure 


The following defines the 512 bytes that make up the Self-test log sector. All multi-byte fields shown in these 
data structures follow the ATA/ATAPI-7 specifications for byte ordering. 


Note: n is 0 through 20 
Table 164 Self-test log data structure 


The data structure contains the descriptor of Self-test that the device has performed. Each descriptor is 24 bytes 
long and the self-test data structure is capable to contain up to 21 descriptors. 


After 21 descriptors have been recorded, the oldest descriptor will be overwritten with new descriptor. 


Self-test index points the most recent descriptor. When there is no descriptor the value is 0. When there is 
descriptor(s) the value is 1 through 21. 
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11.42.7 Selective self-test log data structure 


The Selective self-test log is a log that may be both written and read by the host. This log allows the host to 
select the parameters for the self-test and to monitor the progress of the self-test. The following table defines the 
contents of the Selective self-test log which is 512 bytes long. All multi-byte fields shown in these data structures 
follow the ATA/ATAPI-7 specifications for byte ordering. 


eyes | onsa | rea | 


RIW 
RIW 
RIW 
RIW 
RIW 
RIW 
RIW 
RIW 
RIW 
RIW 


RIW 


154 152h Vendor specific 


Table 165 Selective self-test log data structure 


11.42.7.1 Feature flags 


The Feature flags define the features of Selective self-test to be executed. 
| Bit | Description 

| 0 | Vendor specific 

When set to one, perform off-line scan after selective test. 
Vendor specific 

When set to one, off-line scan after selective test is pending. 
When set to one, off-line scan after selective test is active. 


Reserved. 


Table 166 Selective self-test feature flags 
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11.42.8 Error Reporting 


The following table shows the values returned in the Status and Error Registers when specific error conditions 


are encountered by a device. 


Error Condition Status Register 


A SMART FUNCTION SET command was received by the device without the 
required key being loaded into the Cylinder High and Cylinder Low registers. 


A SMART FUNCTION SET command was received by the device with a 
subcommand value in the Features Register that is either invalid or not 
supported by this device. 


A SMART FUNCTION SET command subcommand other than SMART 
ENABLE OPERATIONS was received by the device while the device was ina 
“SMART disabled” state. 


The device is unable to read its Attribute Values or Attribute Thresholds data 
structure. 


The device is unable to write to its Attribute Values data structure. 


Table 167 SMART Error Codes 
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51h 


51h 


51h 


51h 


51h 


Error 


Register 


04h 


04h 


04h 


10h or 40h 


10h er 0th 


11.43 Standby (E2h/96h) 


ae eee 
oa 
erm 
omarion | 

MYTE) 


Device/Head 


Command Block Input Registers 


a EE 
mm 
sewn [ 
marin | 
ome [oo 


Status Register 


7 6 5 4 3 2 1 0 
BSY | RDY | DF |DSC|DRQ]|]COR]| IDX | ERR 


2 1 0 
1 - 1 D - - - - 
Error Register 


Y 6 4 3 2 1 (0) 
0 | ABT | TON | AMN 


Table 168 Standby Command (E2h/96h) 


The Standby command causes the device to enter the Standby Mode immediately, and set auto power down 
timeout parameter (standby timer). 


When the Standby mode is entered, the drive is spun down but the interface remains active. If the drive is 
already spun down, the spin down sequence is not executed. 


During the Standby mode the device will respond to commands, but there is a delay while waiting for the spindle 
to reach operating speed. 


The automatic power down sequence is enabled and the timer starts counting down when the drive returns to 
Idle mode. 
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Output Parameters To The Device 

Sector Count Timeout Parameter. If zero, the timeout interval (Standby Timer) is NOT disabled. If 
non-zero, then the automatic power down sequence is enabled, and the timeout 
interval is shown blow: 


Value Description 
0 Timer disabled 
1-240 Value *5 seconds 
241-251 (Value-240) * 30 minutes 
252 21 minutes 
253 8 hours 
254 Aborted 
255 21 minutes 15 seconds 


When the automatic power down sequence is enabled, the drive will enter Standby 
mode automatically if the timeout interval expires with no drive access from the host. 
The timeout interval will be reinitialized if there is a drive access before the timeout 
interval expires. 
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11.44 Standby Immediate (E0h/94h) 


Command Block Output Registers 
Dr oe 2. ee GE 


Register — |7 6 5 4 3 2 1 0 
... See Below... 
Cylinder High EEE 
... See Below... 


Status Register 


7 6 4 3 2 1 0 


e 
ae en 
mem | 
ef 
mm fr 


Error Register 


7 6 3 2 1 0 


ABT | TON | AMN BSY | RDY | DF | DSC | DRQ [COR | IDX | ERR 


Table 169 Standby Immediate Command (E0h/94h) 


The Standby Immediate command causes the device to enter Standby mode immediately. 


The device is spun down but the interface remains active. If the device is already spun down, the spin down 
sequence is not executed. 


During the Standby mode, the device will respond to commands, but there is a delay while waiting for the spindle 
to reach operating speed. 


The Standby Immediate command will not affect the auto power down timeout parameter. 


Hitachi hard disk drive specifications 
221 


11.45 Write Buffer (E8h) 


ae ee 
mem | 
me] ee 
oa | 


Command Block Input Registers 


mm | 
Error ... See Below... 

mem | 
ne [ —— 
omme | 


Error Register 


7 6 5 4 3 2 1 0 
CRCIUNC| 0 IDN 0 | ABT | TON | AMN 
eo] 08 0s et ee 


Table 170 Write Buffer Command (E8h) 


Status Register 


7 5 4 3 2 1 0 
BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 


EA EEA 


The Write Buffer command transfers a sector of data from the host to the sector buffer of the device. The sectors 
of data are transferred through the Data Register 16 bits at a time. 


The Read Buffer and Write Buffer commands are synchronized such that sequential Write Buffer and Read 
Buffer commands access the same 512 byte within the buffer. 
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11.46 Write DMA (Cah/CBh) 


Command Block Output Registers Command Block Input Registers 
6 3 2 1 0 


rm | 


6 5 4 3 2 1 0 


7 6 5 4 3 2 1 0 7 
CRCI|UNC| 0 IDN 0 | ABT | TON | AMN BSY | RDY | DF |DSC}DRQ|COR| IDX | ERR 
re PR ee 


Table 171 Write DMA Command (Cah/CBh) 


The Write DMA command transfers one or more sectors of data from the host to the device, then the data is 
written to the disk media. 


The sectors of data are transferred through the Data Register 16 bits at a time. 


The host initializes a slave-DMA channel prior to issuing the command. Data transfers are qualified by DMARQ 
and are performed by the slave-DMA channel. The device issues only one interrupt per command to indicate 
that data transfer has terminated and status is available. 


If an uncorrectable error occurs, the write will be terminated at the failing sector. 
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Output Parameters To The Device 


Sector Count 


Sector Number 


Cylinder High/Low 


H 


R 


The number of continuous sectors to be transferred. If zero is specified, then 256 
sectors will be transferred. 


The sector number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 0 — 7. (L=1) 


The cylinder number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 8 — 15 (Low), 16 — 23 (High). (L=1) 


The head number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 24 — 27. (L=1) 


The retry bit, but this bit is ignored. 


Input Parameters From The Device 


Sector Count 


Sector Number 


Cylinder High/Low 


The number of requested sectors not transferred. This will be zero, unless an 
unrecoverable error occurs. 


The sector number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 0 — 7. (L=1) 


The cylinder number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 8 — 15 (Low), 16 — 23 (High). 
(L=1) 


The head number of the last transferred sector. (L=0) In LBA mode, this register 
contains current LBA bits 24 — 27. (L=1) 
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11.47 Write DMA FUA Ext (3Dh) 


Command Block Output Registers Command Block Input Registers 
easter —Jfrfefsfefefefafe] faer ppp peee 
me H 


Beastie e eee [els 
uret JH 
Feature 
Previous |-[-]-[-1-[-f-]J-]| r 


Sector Count Sector Count 
ørn Tv [v ely [vv [pe 

Sector Number Sector Number 
Prenos |v [vv y vv] 


uren [v v|v|v[v[vfviv 

Cylinder Low Cylinder Low 
Preas [v[v[v[v[v[v[y[v] 
uren f 

Cylinder High Cylinder High 
Prevos [v [v v v v 

Device/Head | }-[a]|-|o|-|-|-|-| [DeviceHead | Device/Head ppg 

eoma o ea 


Error Register Status Register 


KA fw lea EN BC ER 


Table 172 Write DMA FUA Ext Command sie 


The Write DMA FUA Ext command transfers one or more sectors of data from the host to the device, and then 
the data is written to the disk media. This command provides the same function as the Write DMA Ext 
command except that the transferred data shall be written to the media before the ending status for this 
command is reported also when write caching is enabled. 


The sectors of data are transferred through the Data Register 16 bits at a time. 


The host initializes a slave-DMA channel prior to issuing the command. Data transfers are qualified by DMARQ 
and are performed by the slave-DMA channel. The device issues only one interrupt per command to indicate 
that data transfer has terminated and status is available. 


If an unrecoverable error occurs, the write will be terminated at the failing sector. 
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Output Parameters To The Device 


Sector Count Current The number of continuous sectors to be transferred low order, bits (7:0). 
The number of continuous sectors to be transferred high order bits (15:8). If 

Sector Count Previous zero is specified in the Sector Count register, then 65,536 sectors will be 
transferred. 

Sector Number Current LBA (7:0). 

Sector Number Previous LBA (31:24). 

Cylinder Low Current LBA (15:8). 

Cylinder Low Previous LBA (39:32). 

Cylinder High Current LBA (23:16). 

Cylinder High Previous LBA (47:40). 

Input Parameters From The Device 

Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 

Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 

Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 

Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 

Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 

Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 
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11.48 Write DMA Ext (35h) 


Command Block Output Registers Command Block Input Registers 
easter p ppp freser Eeee 
paarow efefeeeløel 
Data High e 
Greek ur 
Feature 
Fe EH ol 


ewet |v|v|v[v[v|v|v|v| 

Sector Count Sector Count 
Previous | v| v |v |v| viv [v|v| 
ewet |v|v|v[v[viv|v|v| 

Sector Number Sector Number 
Previous | v| v |v |v |v [v/v v| 
ewet |v|v|v[v[v|v|v|v| 

Cylinder Low Cylinder Low 
Previous | v | v| v [vv |v |v] v| 
urent |v] vi vi v[viv [vv 

Cylinder High Cylinder High 
Previous | v | v| v [vv |v |v] v| 


Device/Head }-[a}|-[o[-]-]-]-| Device/Head 


cannes Jooo 


<|<|< 
< 
<|< 
<|<|< 


V 
V 
VIV 
V 


< 
<|<|I<|< 
<|< 


< 
< 


< 
<|y<|<|I<|<|<|< 


<|y<|<|I<|<|<|< 


<|< 
<|< 
<|< 
<|< 
< 
< 


Error Register Status Register 


7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 
CRC | UNC 0 IDN 0 ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 
PRES RA eA RES ER ES ETEN ENE EEE EN 


Table 173 Write DMA Ext Command (35h) 


The Write DMA Ext command transfers one or more sectors of data from the host to the device, and then the 
data is written to the disk media. 


The sectors of data are transferred through the Data Register 16 bits at a time. 


The host initializes a slave-DMA channel prior to issuing the command. Data transfers are qualified by DMARQ 
and are performed by the slave-DMA channel. The device issues only one interrupt per command to indicate 
that data transfer has terminated and status is available. 


If an uncorrectable error occurs, the write will be terminated at the failing sector 
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Output Parameters To The Device 


Sector Count Current The number of continuous sectors to be transferred low order, bits (7:0). 
The number of continuous sectors to be transferred high order bits (15:8). If 

Sector Count Previous zero is specified in the Sector Count register, then 65,536 sectors will be 
transferred. 

Sector Number Current LBA (7:0). 

Sector Number Previous LBA (31:24). 

Cylinder Low Current LBA (15:8). 

Cylinder Low Previous LBA (39:32). 

Cylinder High Current LBA (23:16). 

Cylinder High Previous LBA (47:40). 

Input Parameters From The Device 

Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 

Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 

Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 

Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 

Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 

Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 
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11.49 Write FPDMA Queued (61h) 


Command Block Output Registers Command Block Input Registers 
Rose frfefsfefsfefafe] [reser Eepe 
Data High 


Feature 
ri 


eren [v [vv [v[v| [= [=| 
Sector Count Sector Count 
Previous | - | - | -[-| -|-| -| - | 


Sector Number Sector Number 


Cylinder Low Cylinder Low 


Cylinder High Cylinder High 


Device/Head v] E | = | Device/Head 


commen [ols fa fofofofol a) 


Error Register Status Register 


7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 
CRC | UNC 0 IDN 0 ABT | TON | AMN BSY | RDY | DF | DSC | DRQ | COR | IDX | ERR 
PRES EA EEE ENES ETEN ENE EEE EN 


Table 174 Write FPDMA Queued Command (61h) 


The Write FPDMA Queued command transfers one or more sectors of data from the host to the device, and then 
the data is written to the disk media. 


If an unrecoverable error occurs, the write will be terminated at the failing sector 
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Output Parameters To The Device 


Feature Current 

Feature Previous 

Sector Count Current 
TAG (bits 7-3) 


Sector Count Previous 
PRIO (bits 7) 


Sector Number Current 
Sector Number Previous 
Cylinder Low Current 
Cylinder Low Previous 
Cylinder High Current 
Cylinder High Previous 
Device/Head 

FUA (bit 7) 


The number of sectors to be transferred low order, bits (7:0). 
The number of sectors to be transferred high order, bits (15:8). 


The TAG value shall be assigned to be different from all other queued 
commands. The value shall not exceed the maximum queue depth specified by 
the Word 75 of the Identify Device information. 


The Priority (PRIO) value shall be assigned by the host based on the priority of 
the command issued. The device shall make a best effort to complete High 
priority requests in a more timely fashion than Normal priority requests. The 
Priority values are defined as follows: 
Ob Normal priority 
1b High priority 
LBA (7:0) 
LBA (31:24) 
LBA (15:8) 
LBA (39:32) 
LBA (23:16) 
LBA (47:40) 


When the FUA bit is set to 1, the completion status is indicated after the 
transferred data are written to the media also when Write Cache is enabled. 
When the FUA bit is set to 0, the completion status may be indicated before the 
transferred data are written to the media successfully when Write Cache is 
enabled. 


Input Parameters From The Device 


Sector Number (HOB=0) 
Sector Number (HOB=1) 
Cylinder Low (HOB=0) 
Cylinder Low (HOB=1) 
Cylinder High (HOB=0) 
Cylinder High (HOB=1) 


LBA (7:0) of the address of the first unrecoverable error. 
LBA (31:24)of the address of the first unrecoverable error. 
LBA (15:8)of the address of the first unrecoverable error. 
LBA (39:32)of the address of the first unrecoverable error. 
LBA (23:16)of the address of the first unrecoverable error. 


LBA (47:40)of the address of the first unrecoverable error. 
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11.50 Write Log Ext (3Fh) 
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Table 175 Write Log Ext Command (3Fh) 


This command writes a specified number of 512 byte data sectors to the specific log. The device shall interrupt 
for each DRQ block transferred. 


Output Parameters To The Device 
Sector Count Current The number of sectors to be written to the specified log low order, bits (7:0). 


Sector Count Previous The number of sectors to be written to the specified log high orders, bits (15:8). If 
the number of sectors is greater than the number indicated in the Log directory, 
which is available in Log number zero, the device shall return command aborted. 
The log transferred to the device shall be stored by the device starting at the first 
sector in the specified log. 


Sector Number Current The log to be written as described in 0 Log address definition. If the host 
attempts to write to a read only log address, the device shall return command 
aborted. 

Cylinder Low Current The first sector of the log to be written low order, bits (7:0). 

Cylinder Low Previous The first sector of the log to be written high order, bits (15:8). 


If the feature set associated with the log specified in the Sector Number register is not supported or enabled, or if 
the values in the Sector Count, Sector Number or Cylinder Low registers are invalid, the device shall return 
command aborted. If the host attempts to write to a read only log address, the device shall return command 
aborted. 
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11.51 Write Multiple (C5h) 
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Table 176 Write Multiple Command (C5h) 


The Write Multiple command transfers one or more sectors from the host to the device, and then the data is 
written to the disk media. 


Command execution is identical to the Write Sector(s) command except that an interrupt is generated for each 
block (as defined by the Set Multiple command) instead of for each sector. The sectors are transferred through 
the Data Register 16 bits at a time. 
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Output Parameters To The Device 
Sector Count The number of continuous sectors to be transferred. If zero is specified, then 256 
sectors will be transferred. 


Sector Number The sector number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 0 - 7. (L=1) 


Cylinder High/Low The cylinder number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 8 - 15 (Low), 16 - 23 (High). (L=1) 


H The head number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 24 - 27. (L=1) 


Input Parameters From The Device 


Sector Count The number of requested sectors not transferred. This will be zero, unless an 
unrecoverable error occurs. 


Sector Number The sector number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 0 - 7. (L=1) 


Cylinder High/Low The cylinder number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 8 - 15 (Low), 16 - 23 (High). (L=1) 


H The head number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 24 - 27. (L=1) 
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11.52 Write Multiple Ext (39h) 
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Table 177 Write Multiple Ext Command (39h) 


The Write Multiple Ext command transfers one or more sectors from the host to the device, and then the data is 
written to the disk media. 


Command execution is identical to the Write Sector(s) Ext command except that an interrupt is generated for 
each block (as defined by the Set Multiple command) instead of for each sector. The sectors are transferred 
through the Data Register 16 bits at a time. 
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Output Parameters To The Device 


Sector Count Current The number of continuous sectors to be transferred low order, bits (7:0) 

Sector Count Previous The number of continuous sectors to be transferred high order, bits (15:8). 
zero is specified in the Sector Count register, then 65,536 sectors shall be 
transferred. 

Sector Number Current LBA (7:0). 

Sector Number Previous LBA (31:24). 

Cylinder Low Current LBA (15:8). 

Cylinder Low Previous LBA (39:32). 

Cylinder High Current LBA (23:16). 

Cylinder High Previous LBA (47:40). 

Input Parameters From The Device 

Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 

Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 

Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 

Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 

Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 

Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 
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11.53 Write Multiple FUA Ext (CEh) 
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Table 178 Write Multiple FUA Ext Command (CEh) 
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The Write Multiple Ext command transfers one or more sectors from the host to the device, and then the data is 
written to the disk media. This command provides the same function as the Write Multiple Ext command 
except that the transferred data shall be written to the media before the ending status for this command is 
reported also when write caching is enabled. 


Command execution is identical to the Write Sector(s) Ext command except that an interrupt is generated for 
each block (as defined by the Set Multiple command) instead of for each sector. The sectors are transferred 
through the Data Register 16 bits at a time. 
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Output Parameters To The Device 


Sector Count Current The number of continuous sectors to be transferred low order, bits (7:0) 

Sector Count Previous The number of continuous sectors to be transferred high order, bits (15:8). 
zero is specified in the Sector Count register, then 65,536 sectors shall be 
transferred. 

Sector Number Current LBA (7:0). 

Sector Number Previous LBA (31:24). 

Cylinder Low Current LBA (15:8). 

Cylinder Low Previous LBA (39:32). 

Cylinder High Current LBA (23:16). 

Cylinder High Previous LBA (47:40). 

Input Parameters From The Device 

Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 

Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 

Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 

Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 

Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 

Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 
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11.54 Write Sector(s) (30h/31h) 
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Table 179 Write Sector(s) Command (30h/31h) 


The Write Sector(s) command transfers one or more sectors from the host to the device,and then the data is 
written to the disk media. 


The sectors are transferred through the Data Register 16 bits at a time. 


If an uncorrectable error occurs, the write will be terminated at the failing sector. 
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Output Parameters To The Device 


Sector Count 
Sector Number 
Cylinder High/Low 
H 


R 


The number of continuous sectors to be transferred. If zero is specified, then 256 
sectors will be transferred. 


The sector number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 0 - 7. (L=1) 


The cylinder number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 8 - 15 (Low), 16 - 23 (High). (L=1) 


The head number of the first sector to be transferred. (L=0) 
In LBA mode, this register contains LBA bits 24 - 27. (L=1) 


The retry bit, but this bit is ignored. 


Input Parameters From The Device 


Sector Count 


Sector Number 


Cylinder High/Low 


The number of requested sectors not transferred. This will be zero, unless an 
unrecoverable error occurs. 


The sector number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 0 - 7. (L=1) 


The cylinder number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 8 - 15 (Low), 16 - 23 (High). 
(L=1) 


The head number of the last transferred sector. (L=0) 
In LBA mode, this register contains current LBA bits 24 - 27. (L=1) 
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11.55 Write Sector(s) Ext (34h) 
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Table 180 Write Sector(s) Ext Command (34h) 
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The Write Sector(s) Ext command transfers one or more sectors from the host to the device, and then the data is 
written to the disk media. 


The sectors are transferred through the Data Register 16 bits at a time. 


If an uncorrectable error occurs, the write will be terminated at the failing sector. 
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Output Parameters To The Device 


Sector Count Current The number of continuous sectors to be transferred low order, bits (7:0). 

Sector Count Previous The number of continuous sectors to be transferred high order bits (15:8). If zero 
is specified, then 65,536 sectors will be transferred. 

Sector Number Current LBA (7:0). 

Sector Number Previous LBA (31:24). 

Cylinder Low Current LBA (15:8). 

Cylinder Low Previous LBA (39:32). 

Cylinder High Current LBA (23:16). 

Cylinder High Previous LBA (47:40). 


Input Parameters From The Device 
Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 
Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 


Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 

Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 
Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 
Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 
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11.56 Write Stream DMA (3Ah) 
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Table 181 Write Stream DMA Command (3Ah) 


The Write Stream DMA command allows the host to write data using the DMA data transfer protocol. This 
command allows for the host to specify to the device that additional actions need to be performed prior to the 
completion of the command if the required bits are set. 


If the Write Continuous bit is set to one, the device shall not stop execution of the command due to errors. If 
the WC bit is set to one and errors occur in the transfer or writing of the data, the device shall continue to transfer 
the amount of data requested and then provide ending status with the BSY bit cleared to zero, the SE bit set to 
one, the ERR bit cleared to zero, and the type of error, ICRC, IDNF, or ABRT, reported in the error log. If the 
WC bit is set to one and the Command Completion Time Limit expires, the device shall stop execution of the 
command and provide ending status with BSY bit cleared to zero, the SE bit set to one, the ERR bit cleared to 
zero, and report the fact that the Command Completion Time Limit expired by setting the CCTO bit in the error 
log to one, In all cases, the device shall attempt to transfer the amount of data requested within the Command 
Completion Time Limit event if some data transferred is in error. 
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Output Parameters To The Device 


Feature Current 


URG (bit7) 


WC (bit6) 


F (bit5) 


HSE (bit4) 


Stream ID (bit 0..2) 


Feature Previous 
CCTL (7:0) 


Sector Count Current 
Sector Count Previous 


Sector Number Current 
Sector Number Previous 
Cylinder Low Current 
Cylinder Low Previous 
Cylinder High Current 
Cylinder High Previous 


URG specifies an urgent transfer request. The Urgent bit specifies that the 
command should be completed in the minimum possible time by the device and 
shall be completed within the specified Command Completion Time Limit. 


WC specifies Write Continuous mode enabled. If the Write Continuous bit is set 
to one, the device shall not stop execution of the command due to errors. 

If the WC bit is set to one and errors occur in transfer or writing of the data, the 
device shall continue to transfer the amount of data requested and then provide 
ending status with BSY bit cleared to zero, the SE bit set to one, the ERR bit 
cleared to zero, and the type of error, ICRC, IDNF or ABRT reported in the error 
log. 

If the WC bit is set to one and the Command Completion Time Limit expires, the 
device shall stop execution of the command and provide ending status with the 
BSY bit cleared to zero, the SE bit set to one, the ERR bit cleared to zero, and 
report the fact that the Command Completion Time Limit expired by setting the 
CCTO bit in the error log to one. 

In all cases, the device shall attempt to transfer the amount of data requested 
within the Command Completion Time Limit even if some data transferred is in 
error. 

F specifies that all data for the specified stream shall be flushed to the media 
before command complete is reported when set to one. 

HSE (Handle Stream Error) specifies that this command starts at the LBA of the 
last reported error for this stream, so the device may attempt to continue its 
corresponding error recovery sequence where it left off earlier. 


Stream ID specifies the stream being written. The device shall operate 
according to the Stream ID set by the Write Stream command. 
The time allowed for the current command's completion is calculated as follows: 
Command Completion Time Limit = (content of the Feature register 
Previous) * (Identify Device words (99:98)) useconds 
If the value is zero, the device shall use the Default CCTL supplied with a previous 
Configure Stream command for this Stream ID. If the Default CCTL is zero, or 
no previous Configure Stream command was defined for this Stream ID, the 
device will ignore the CCTL. The time is measured from the write of the 
command register to the final INTRQ for command completion. The device has 
minimum CCTL value. When the specified value is shorter than the minimum 
value, CCTL is set to the minimum value. Actual minimum CCTL value is 
described in the “Deviations from Standard” section. 
The number of continuous sectors to be transferred low order, bits (7:0) 


The number of continuous sectors to be transferred high order, bits (15:8). If 
zero is specified in the Sector Count register, then 65,536 sectors will be 
transferred. 
LBA (7:0). 


LBA (31:24). 
LBA (15:8). 

LBA (39:32). 
LBA (23:16). 
LBA (47:40). 


Input Parameters From The Device 


Sector Number (HOB=0) 


LBA (7:0) of the address of the first unrecoverable error. 
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Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 
Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 

Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 
Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 
Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 


CCTO (Error, bit 0) CCTO bit shall be set to one if a Command Completion Time Limit Out error has 
occurred. 
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11.57 Write Stream PIO (3Bh) 
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Table 182 Write Stream PIO Command (3Bh) 


This command writes from 1 to 65536 sectors as specified in the Sector Count register. A sector count of 0 
requests 65536 sectors. 


If the Write Continuous bit is set to one, the device shall not stop execution of the command due to errors. If 
the WC bit is set to one and errors occur in the transfer or writing of the data, the device shall continue to transfer 
the amount of data requested and then provide ending status with the BSY bit cleared to zero, the SE bit set to 
one, the ERR bit cleared to zero, and the type of error, IDNF, or ABRT, reported in the error log. If the WC bit is 
set to one and the Command Completion Time Limit expires, the device shall stop execution of the command 
and provide ending status with BSY bit cleared to zero, the SE bit set to one, the ERR bit cleared to zero, and 
report the fact that the Command Completion Time Limit expired by setting the CCTO bit in the error log to one, 
In all cases, the device shall attempt to transfer the amount of data requested within the Command Completion 
Time Limit event if some data transferred is in error. 
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Output Parameters To The Device 


Feature Current 


URG (bit7) 


WC (bit6) 


F (bit5) 


HSE (bit4) 


Stream ID (bit 0..2) 


Feature Previous 


Sector Count Current 
Sector Count Previous 


Sector Number Current 
Sector Number Previous 
Cylinder Low Current 
Cylinder Low Previous 
Cylinder High Current 
Cylinder High Previous 


URG specifies an urgent transfer request. The Urgent bit specifies that the 
command should be completed in the minimum possible time by the device and 
shall be completed within the specified Command Completion Time Limit. 


WC specifies Write Continuous mode enabled. If the Write Continuous bit is 

set to one, the device shall not stop execution of the command due to errors. 

If the WC bit is set to one and errors occur in transfer or writing of the data, the 

device shall continue to transfer the amount of data requested and then provide 

ending status with BSY bit cleared to zero, the SE bit set to one, the ERR bit 
cleared to zero, and the type of error, IDNF or ABRT reported in the error log. 

If the WC bit is set to one and the Command Completion Time Limit expires, the 

device shall stop execution of the command and provide ending status with the 

BSY bit cleared to zero, the SE bit set to one, the ERR bit cleared to zero, and 

report the fact that the Command Completion Time Limit expired by setting the 

CCTO bit in the error log to one. 

In all cases, the device shall attempt to transfer the amount of data requested 

within the Command Completion Time Limit even if some data transferred is in 

error. 

F specifies that all data for the specified stream shall be flushed to the media 

before command complete is reported when set to one. 

HSE (Handle Stream Error) specifies that this command starts at the LBA of the 

last reported error for this stream, so the device may attempt to continue its 

corresponding error recovery sequence where it left off earlier. 

Stream ID specifies the stream being written. The device shall operate 

according to the Stream ID set by the Write Stream command. 

The time allowed for the current command's completion is calculated as follows: 
Command Completion Time Limit = (content of the Feature register 
Previous) * (Identify Device words (99:98)) useconds 

If the value is zero, the device shall use the Default CCTL supplied with a 

previous Configure Stream command for this Stream ID. If the Default CCTL 

is zero, or no previous Configure Stream command was defined for this Stream 

ID, the device will ignore the CCTL. The time is measured from the write of the 

command register to the final INTRQ for command completion. The device has 

minimum CCTL value. When the specified value is shorter than the minimum 
value, CCTL is set to the minimum value. Actual minimum CCTL value is 
described in the “Deviations from Standard” section. 

The number of continuous sectors to be transferred low order, bits (7:0) 


The number of continuous sectors to be transferred high order, bits (15:8). If 
zero is specified in the Sector Count register, then 65,536 sectors will be 
transferred. 


LBA (7:0). 
LBA (31:24). 
LBA (15:8). 
LBA (39:32). 
LBA (23:16). 
LBA (47:40). 
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Input Parameters From The Device 

Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 
Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 
Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 
Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 
Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 
Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 


CCTO (Error, bit 0) CCTO bit shall be set to one if a Command Completion Time Limit Out error has 
occurred. 
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11.58 Write Uncorrectable Ext (45h) 
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Table 183 Write Uncorrectable Ext Command (45h) 


Command 


Bodd 


The Write Uncorrectable Ext command is used to cause the device to report an uncorrectable error when the 
target sector is subsequently read. 

When the Feature field contains a value of 55h the Write Uncorrectable Ext command shall cause the device to 
indicate a failure when reads to any of the sectors that are contained in physical block of specified sector are 
performed. These sectors are referred to as ‘pseudo uncorrectable’ sectors. In this case whenever a pseudo 
uncorrectable sector is accessed via a read command the drive shall perform normal error recovery to the fullest 
extent and then set the UNC and ERR bits to indicate the sector is bad. 

When the Feature field(7:0) contains a value of AAh the Write uncorrectable ext command shall cause the 
device to flag the specified sector as ‘flagged uncorrectable’. Flagging a logical sector as uncorrectable shall 
cause the device to indicate a failure when reads to the specified sector are performed. These sectors are 
referred to as ‘flagged uncorrectable’ sectors. In this case whenever a ‘flagged uncorrectable’ sector is accessed 
via a read command the device shall set the UNC and ERR bits to indicate the sector is bad. 

If this command is sent to the device with the content of the Features field(7:0) set to anything other than what is 
defined above the device shall abort the command. 

Commands that return UNC and ERR when a pseudo uncorrectable or flagged uncorrectable sector is read 
include: READ DMA,READ DMA EXT, READ MULTIPLE, READ MULTIPLE EXT, READ SECTOR(S), READ 
SECTOR(S) EXT, READ VERIFY SECTOR(S), READ, VERIFY SECTOR(S) EXT, READ STREAM EXT, READ 
STREAM DMA EXT. if the host writes to a ‘pseudo uncorrectable’ or ‘flagged uncorrectable’ sector, the drive 
shall attempt to write the data to the sector. The write shall clear the uncorrectable status of the sector and make 
the sector good if possible and the device shall verify that the sector may now be read without error. It is possible 
that an ‘uncorrectable’ sector location has actual physical errors. In this case read commands and/or write 
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commands shall return ERR status information that is consistent with the error. The pseudo uncorrectable or 
flagged uncorrectable status of a sector shall remain through a power cycle. If the drive is unable to process a 
Write Uncorrectable EXT command for any reason the device shall abort the command. 


Output Parameters To The Device 
Feature Current Uncorrectable options 


55h :Create a pseudo-uncorrectable error with logging 
AAh :Created a flagged error without logging 
Other value : Reserved 


Sector Count Current The number of continuous sectors to be transferred low order, bits (7:0). 

Sector Count Previous The number of continuous sectors to be transferred high order bits (15:8). If zero 
is specified, then 65,536 sectors will be transferred. 

Sector Number Current LBA (7:0). 

Sector Number Previous LBA (31:24). 

Cylinder Low Current LBA (15:8). 

Cylinder Low Previous LBA (39:32). 

Cylinder High Current LBA (23:16). 

Cylinder High Previous LBA (47:40). 


Input Parameters From The Device 
Sector Number (HOB=0) LBA (7:0) of the address of the first unrecoverable error. 
Sector Number (HOB=1) LBA (31:24) of the address of the first unrecoverable error. 


Cylinder Low (HOB=0) LBA (15:8) of the address of the first unrecoverable error. 

Cylinder Low (HOB=1) LBA (39:32) of the address of the first unrecoverable error. 
Cylinder High (HOB=0) LBA (23:16) of the address of the first unrecoverable error. 
Cylinder High (HOB=1) LBA (47:40) of the address of the first unrecoverable error. 
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12 Timings 


The timing of BSY and DRQ in Status Register are shown in Table 184. 


The other timings are described in HDS723030ALA64n / HUA7230xxALA64n / HDS5C3030ALA63n / 
HUA5C30xxALA64n Final Functional Specification. 


FUNCTION INTERVAL START STOP TIMEOUT 


Power On Device Busy after Power On | Power On The device sets BSY(=0) and 31 sec 
and RDY(=1) to the Status 
COMRESET Register and sends a Register 


FIS to the host. 


Software Device Busy after Software | The host asserts SRST(=1) The Host sets BSY(=1) to the 400 ns 
Reset Reset in the Device Control Status Register. 
Register and sends a 
Register FIS to the Device. 
Device Ready after The host asserts SRST(=1) The device sets BSY(=0) and 31 sec 
Software Reset to the Device Control RDY(=1) to the Status 
Register and sends a Register and requests to send 
Register FIS to the Device. a Register FIS to the host. 
Then the host negates 
SRST(=0) to the Device 
Control Register and sends a 
Register FIS to the Device. 


COMRESET | Device Ready after | COMRESET Signal asserted | The device sets BSY(=0) and 31 sec 
COMRESET RDY(=1) to the Status 


Register and sends a Register 
FIS to the Host. 


Non-Data Device Busy after a Register | The host sets proper values The host sets BSY(=1) to the 400 ns 
command FIS to issue a command in the registers and sends a Status register 
Register FIS 


A Register FIS to report The host sets BSY(=1) to the | The device sets the status of 

Command Complete Status Register the command to the Status 
Register and sends a Register 
FIS to the host 


PIO Data In | Device Busy after a Register | The host sets proper values The host sets BSY(=1) to the 400 ns 
command FIS to issue a command in the registers and sends a Status Register 
Register FIS 


PIO SETUP FIS for data-in The host sets BSY(=1) to the | The device sets BSY(=0) and 

transfer Status Register DRQ(=1) to the Status 
Register and sends a PIO 
SETUP FIS to the host. 


Device Busy after data-in A PIO SETUP FIS is The host sets BSY(=1) to the 400 ns 
transfer transferred to the host. Status Register 
PIO Data Device Busy after a Register | The host sets proper values The host sets BSY(=1) to the 400 ns 
Out FIS to issue a command in the registers and sends a Status Register 
Command Register FIS 
Device Busy after data-out The host sends a Data FIS to | The host sets BSY(=1) to the 400 ns 
transfer the device. Status Register 


PIO SETUP FIS for data-out | The host sets BSY(=1) to the | The device sets BSY(=0) and 

transfer Status Register DRQ(=1) to the Status 
Register and sends a PIO 
SETUP FIS to the host. 


Table 184 Timeout Values 
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Command category is referred to 10, “Command Protocol" on page 92. 


The abbreviations "ns", "us", "ms" and "sec" mean nanoseconds, microseconds, milliseconds and seconds, 


respectively. 


We recommend that the host system executes Soft reset and then retries to issue the command if the host 
system timeout would occur for the device. 
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